# rogrammierung

#### Das umfassende Handbuch zum 68000-Prozessor

Der 68000 ist einer der ersten aus der Generation der 32-bit-Mikroprozessoren. Er bildet das Herz von leistungsstarken Computern wie Atari ST, Macintosh und Sinclair QL. Mit diesem Buch lernen Sie ohne Schwierigkeiten seine Möglichkeiten kennen und nutzen. Systematisch und schrittweise werden Sie mit dem 68000 vertraut gemacht:

Im ersten Teil wird die Struktur des Mikroprozessors beschrieben. Der zweite Teil stellt Ihnen Aufbau des Speichers, Adreßmodi und den Befehlssatz vor. Das Schlußkapitel gibt einen Überblick über die anderen Mitglieder der Prozessorfamilie: 68008, 68010, 68012 und 68020.

Zahlreiche Beispiele helfen Ihnen, das erworbene Wissen zu überprüfen und direkt praktisch anzuwenden.

#### Über die Autorin:

C. Vieillefond hat ihr Diplom an der Fachhochschule für Ingenieurwesen. Elektronik und Elektrotechnik gemacht. Sie hat bereits zahlreiche Fachartikel veröffentlicht.

3-88745-060-4

# Programmierung





C. Vieillefond

#### Anmerkungen:

68000 ist ein geschütztes Warenzeichen von Motorola

Originalausgabe in Französisch Titel der Originalausgabe: MISE EN OEUVRE DU 68000 Original Copyright © SYBEX 1984

#### Deutsche Übersetzung: Iris Cantarellas

Umschlaggestaltung: Jean-François Pénichoux/tgr Satz: tgr — typo-grafik-repro gmbh, Remscheid Gesamtherstellung: Boss-Druck und Verlag, Kleve

Der Verlag hat alle Sorgfalt walten lassen, um vollständige und akkurate Informationen zu publizieren. SYBEX-Verlag GmbH, Dusseldorf, übernimmt keine Verantwortung für die Nutzung dieser Informationen, auch nicht für die Verletzung von Patent- und anderen Rechten Dritter, die daraus resultieren.

Alle deutschsprachigen Rechte vorbehalten. Kein Teil des Werkes darf in irgendeiner Form (Druck, Fotokopie, Mikrofilm oder einem anderen Verfahren) ohne schriftliche Genehmigung des Verlages reproduziert oder unter Verwendung elektronischer Systeme verarbeitet, vervielfältigt oder verbreitet werden.

ISBN 3-88745-060-4 1. Auflage 1985

Printed in Germany Copyright © 1985 by SYBEX-Verlag GmbH, Düsseldorf

# Inhaltsverzeichnis

| Kapitel 1: Grundlagen  Die Signale des MC68000  Der interne Aufbau des MC68000  Die Zyklen |   |   | . 9<br>. 23 |
|--------------------------------------------------------------------------------------------|---|---|-------------|
| Kapitel 2: Allgemeine Organisation von Datenübertragungen                                  |   |   | . 31        |
| Übertragungen im Asynchron-Modus                                                           |   |   |             |
| Lesezyklus                                                                                 |   |   |             |
| Schreibzyklus                                                                              |   |   | . 40        |
| Lese-/Änderungs-/Schreibzyklus                                                             |   |   |             |
|                                                                                            |   |   |             |
| Zyklusstörungen                                                                            |   |   | . 55        |
| Synchrone Datenübertragung                                                                 |   |   |             |
| Buszuweisungssteuerung                                                                     |   |   |             |
| Kapitel 3: Die Ausnahmezustände                                                            |   |   | . 77        |
| Allgemeine Betrachtungen                                                                   |   |   |             |
| Die Ausnahmevektoren                                                                       |   |   |             |
| Verarbeitung einer Ausnahme                                                                |   |   |             |
| Bearbeitung der unterschiedlichen Ausnahmetypen                                            | - |   |             |
| Unterbrechungen                                                                            |   |   |             |
| Rücksetzung (RESET)                                                                        | • | 1 |             |
| Befehle des Typs TRAP                                                                      |   |   |             |
| Illegale und nichtimplementierte Befehle                                                   |   |   |             |
| Nichtautorisierte Verwendung privilegierter Befehle                                        |   |   |             |
| Die Betriebsart TRACE                                                                      |   |   |             |
| Busfehler                                                                                  |   |   |             |
| Adreßfehler                                                                                |   | ٠ | 100         |
| Die nichtinitialisierte Unterbrechung                                                      | ٠ | ٠ | 105         |
| the monocalistic interpretation                                                            | _ |   |             |

| Kapitel 4: Die Speicherverwaltung                     | . 107 |
|-------------------------------------------------------|-------|
| Datenorganisation im Speicher und die Bedingungscodes | . 107 |
| Das Bedingungscoderegister CCR                        | . 110 |
| Die Adressierungsarten                                | . 113 |
| Absolute Adressierung                                 | . 114 |
| Direkte Registeradressierung                          | . 121 |
| Unmittelbare Adressierung                             | . 126 |
| Adressierungsart Adreßregister indirekt               | . 129 |
| Adressierungsarten relativ zum Programmzähler         | . 144 |
| Kapitel 5: Der Befehlssatz des 68000                  | 155   |
| Beschreibung des Befehlssatzes                        |       |
| Detaillierte Betrachtung einzelner Befehle            | 302   |
| Der Befehl Bcc                                        | 302   |
| Der Befehl LEA                                        | 304   |
| Der Befehl DBcc                                       |       |
| Der Befehl EXT                                        |       |
| Der Refehl SWAP                                       | 311   |
| Der Befehl SWAP                                       | 312   |
| Der Befehl Scc                                        | 315   |
| Die Befehle für Dezimalarithmetik ABCD, SBCD und NBCD | 316   |
| Die Verschiebe- und Ringverschiebungsbefehle:         | . 510 |
| ASR, ASL, LSR, LSL, ROXR, ROXL, ROR, ROL              | 320   |
| Der Befehl CHK                                        |       |
| Der Befehl MOVEM                                      | 324   |
| Der Befehl MOVEP                                      | 330   |
| Der Befehl PEA                                        |       |
| Der Befehl TAS                                        |       |
| Die Befehle für Bitmanipulationen:                    |       |
| BTST, BSET, BCLR, BCHG                                | . 343 |
| Der Befehl LINK                                       | . 346 |
| Der Befehl UNLK                                       |       |
| LINK und UNLK                                         |       |
|                                                       |       |
| Kapitel 6: Anwenderprogramme                          | . 365 |
| Programm 1                                            |       |
| Programm 2                                            |       |
| Programm 3                                            |       |
| Programm 4                                            |       |
| Programm 5                                            |       |
| Programm 6                                            | . 372 |

Inhaltsverzeichnis 7

| Programm 7                                          |     |   |   |   |   |   |    |   |   | 377 |
|-----------------------------------------------------|-----|---|---|---|---|---|----|---|---|-----|
|                                                     |     |   |   |   |   |   |    |   |   |     |
|                                                     |     |   |   |   |   |   |    |   |   |     |
| Programm 9                                          |     |   |   |   | • | • | •  | • | • | 202 |
| Kapitel 7: Die anderen Prozessoren der 68000-Fami   | lie |   |   |   | 4 |   | à. |   |   | 387 |
| Der MC68008                                         |     |   |   |   |   |   |    |   |   |     |
| Lesezyklus                                          |     |   |   |   |   |   |    |   |   |     |
| Schreibzyklus                                       |     |   |   |   |   |   |    |   | 4 | 391 |
| Verbindung mit 6800-Bausteinen                      |     |   |   |   |   |   |    |   | , | 394 |
| Buszuweisungssteuerung                              | ,   |   |   |   |   |   |    |   |   | 397 |
| Die Ausnahmeprozeduren                              |     |   |   |   | * |   |    |   |   | 398 |
| Der Befehlssatz                                     |     |   |   |   |   |   |    |   |   |     |
| Der MC68010                                         |     |   | _ | _ |   |   |    |   |   | 400 |
| Allgemeines                                         |     |   | _ |   |   |   |    |   | , | 400 |
| Interne Struktur des MC68010                        |     |   |   |   |   |   |    |   |   |     |
| Die Anschlüsse des MC68010                          |     |   |   |   |   |   |    |   |   | 403 |
| Die Ausnahmen                                       |     |   |   |   |   |   |    |   |   |     |
| Die Befehle                                         |     |   |   |   |   |   |    |   |   | 412 |
| Der MC68012                                         |     |   |   |   |   |   |    |   |   | 422 |
| Der MC68020                                         |     |   |   |   |   |   |    |   |   | 424 |
| Der Cache-Speicher                                  |     |   |   |   |   |   |    |   |   | 425 |
| Transfer über den Bus                               |     |   |   |   |   |   |    |   |   | 425 |
| Die Programmierung des MC68020                      |     |   |   | Ţ |   | Ì |    |   |   | 426 |
| Die Hogrammetung des Meedoods                       | -   | • |   | • | - |   |    |   |   |     |
|                                                     |     |   |   |   |   |   |    |   |   |     |
| Anhang                                              |     |   |   |   |   |   |    |   |   |     |
| A: Ausführungszeiten der Befehle des MC68000        |     |   |   |   |   |   |    |   | 4 | 427 |
| <b>B:</b> Ausführungszeiten der Befehle des MC68008 |     |   |   |   |   | , |    |   |   | 434 |
| C: Ausführungszeiten der Befehle des MC68010        |     |   |   |   |   |   |    |   |   | 441 |
| O .                                                 |     |   |   |   |   |   |    |   |   |     |
| Stichwortverzeichnis                                |     |   |   |   |   |   |    |   | , | 451 |



# Kapitel 1 Grundlagen

Der Prozessorchip 68000 präsentiert sich uns in einem Gehäuse mit 64 Anschlußstiften. Die erhöhte Anzahl der Anschlußstifte (im Vergleich zu anderen Mikroprozessoren) kommt einerseits dadurch zustande, daß die Daten- und Adreßbusse getrennt ausgeführt sind (es wird daher kein Multiplexing benötigt), und andererseits dadurch, daß dieser Mikroprozessor mit einer sehr vollständigen Signalpalette ausgestattet ist.

Das Anschlußschema dieses Prozessors ist in Abb. 1.1 zu sehen.

#### DIE SIGNALE DES MC68000

Die Ein- und Ausgänge des Gehäuses können nach Funktionen gruppiert werden, wie es das Diagramm der Abb. 1.2 zeigt.

Drei Kategorien von Anschlüssen erscheinen in diesem Diagramm:

- 1. die Stromversorgungen und der Takteingang;
- 2. der Adreß- und der Datenbus;
- 3. die Steuersignale, die außerdem noch 6 Gruppen bilden.

Bevor eine Untersuchung der Funktionen der Anschlüsse im einzelnen

#### Die Stromversorgungen: (2) VCC und (2) GND

Der MC68000 benötigt eine einzige Stromyersorgung von 5 Volt. Es fällt jedoch auf, daß die Anschlußstifte VCC und GND doppelt ausgeführt und so zentral plaziert sind, daß aufgrund der daraus resultierenden kurzen Leitungswege innerhalb des Gehäuses die Stromverluste minimal gehalten werden.



Abb. 1.1: Die Pinbelegung des MC68000

## Der Takteingang: CLK

Das Eingangssignal des Taktgebers muß TTL-kompatibel und symmetrisch sein; es wird vom Mikroprozessor für das Generieren der internen Uhr benötigt.



Abb. 1.2: Die Funktionen des MC68000

- 1. Die niedrigste Frequenz ist 2 MHz.
- Die Anstiegs- und Abfallzeiten dürfen höchstens eine maximale Zeitdauer von 10 ns haben.
- 3. Für die unterschiedlichen Versionen des MC68000 (L4: 4 MHz, L6: 6 MHz, L8: 8 MHz, L10: 10 MHz, L12: 12.5 MHz) definieren wir eine minimale und maximale Impulslänge.



Abb. 1.3: Die Form des Taktgebersignals

Die Form des Taktgebersignals ist in Abb. 1.3 zu sehen.

Die minimale Zykluszeit der Version L8 ist 128 ns.

Im allgemeinen kann ein 8-MHz-Taktgeber mit einer angelegten Taktfrequenz von 16 MHz generiert werden. Wir schauen uns einmal eine solche Schaltung zur Generierung eines 8-MHz-Taktgebers an (Abb. 1.4) und

fassen dann die Taktgeber-Merkmale für die verschiedenen Versionen des 68000 zusammen (Abb. 1.5 und 1.6).



Abb. 1.4: Beispiel zur Realisierung eines 8-MHz-Taktgebers

|            | Abkurzungen       | 4 MHz<br>MC68000 L4 |     | 6 MHz<br>MC68000 L6 |     | 8 MHz<br>MC68000 L8 |     | 10 A<br>MC680 |     | 12.5<br>MC680 | Ein-<br>heiten |     |
|------------|-------------------|---------------------|-----|---------------------|-----|---------------------|-----|---------------|-----|---------------|----------------|-----|
| Frequenz   | F                 | 2                   | 4   | 2                   | 6   | 2                   | 8   | 5             | 10  | 4             | 12,5           | MHz |
| Zykluszeit | L <sub>EY</sub> 4 | 500                 | 250 | 500                 | 167 | 500                 | 125 | 500           | 100 | 250           | 80             | 75  |

Abb 15. Tabelle der Zykluszeiten abhängig von den Frequenzen der verschiedenen Versionen

|                             | Abkürzungen      | i .        | MAX        |          | IHz<br>000L6<br>MAX | 1 -      | IHz<br>000 LB<br>MAX |          | MHz<br>XXX L10<br>MAX |          | MHz<br>XXX L12<br>MAX | Ein-<br>helten |
|-----------------------------|------------------|------------|------------|----------|---------------------|----------|----------------------|----------|-----------------------|----------|-----------------------|----------------|
| Zykluszeit                  | t <sub>zyk</sub> | 250        | 500        | 167      | 500                 | 125      | 500                  | 100      | 500                   | 60       | 250                   | ns             |
| Impulslänge                 | t <sub>t</sub>   | 115<br>115 | 250<br>250 | 75<br>75 | 250<br>250          | 55<br>55 | 250<br>250           | 45<br>45 | 250<br>250            | 35<br>35 | 125<br>125            | ns             |
| Anstiegs- und<br>Abfallzeit | t <sub>An</sub>  | -          | 10<br>10   | -        | 10                  | -        | 10<br>10             | -        | 10                    | -        | 5<br>5                | na             |

Abb. 1.6 Tabelle der minimalen und maximalen Zeiten

#### Der Datenbus: D0-D15

Der Datenbus ist ein 16-Bit-Datenbus, d. h. er kann 8 oder 16 Datenbits parallel (also gleichzeitig) übertragen. Er kann drei Zustände annehmen (tristate) und ist außerdem bidirektional, d. h. er überträgt in beide Rich tungen.

#### Der Adreßbus: A1-A23

Der Adreßbus ist ein 23 Bit breiter, unidirektionaler Tristate-Bus, der 8 Mega Datenworte (2<sup>24</sup> entsprechen 16 Megabyte) adressieren kann.

Es fällt auf, daß dieser Bus keinen Ausgang mit der Bezeichnung A0 hat. A0 wird durch 2 Signale UDS (Upper Data Strobe) und LDS (Lower Data Strobe) ersetzt, die abhangig vom Typ der adressierten Daten vom 68000 angesprochen werden. Diese Signale werden im folgenden Abschnitt näher besprochen.

# Steuersignale des Busses im Asynchron-Modus: AS, R/W, UDS, LDS, DTACK

Im asynchronen Modus arbeitet der Prozessor wie folgt: Nachdem der Mikroprozessor eine Anfrage für eine Datenübertragung an ein peripheres Gerät geschickt hat, wartet er auf eine Antwort von dem angesprochenen Gerät. Der Prozessor stellt sich also auf die Geschwindigkeit des Peripheriegerates oder des Speichers, mit dem er kommunizieren soll, ein.

Die Signale, die für diesen Typ des Datenaustauschs benötigt werden, sind die folgenden:

# AS, R/W, UDS, LDS, DTACK

# AS Address Strobe/Adressimpuls

Dieses Signal weist darauf hin, daß der Bus augenblicklich eine gültige Adresse enthält.

## R/W Read-Write/Lesen-Schreiben

Dieses Signal definiert den Übertragungstyp der Daten auf dem Bus, also entweder Lesen oder Schreiben.

UDS, LDS Upper, Lower Data Strobe/Impuls höher-bzw. mederwertiger Daten

Diese Signale werden intern im MC68000 generiert und sind abhängig vom Datentyp, der übertragen werden soll, und von A0. In Verbindung mit dem R/W-Signal bestimmen  $\overline{UDS}$  und  $\overline{LDS}$  den Lese- oder Schreibvorgang eines Wortes oder eines Bytes.

Bevor wir die unterschiedlichen Kombinationen dieser drei Signale betrachten (Abb. 1.7) wollen wir zunächst die Speicherorganisation näher betrachten und die Begriffe Wort (16 Bits) und Byte (8 Bits) klären.

|             | 15           | 8 7         | 0 |
|-------------|--------------|-------------|---|
| Wort 000000 | Byte 0000000 | Byte 000001 |   |
| Wort 000002 | Byte 0000002 | Byte 000003 |   |
| Wort 000004 | Byte 0000004 | Byte 000005 |   |
|             |              |             |   |
|             |              |             |   |
| Wort FFFFFE | Byte FFFFFE  | Byte FFFFFF |   |

Bytes an geraden Adressen Bytes an ungeraden Adressen

| UDS | LDS | R/W | D8-D15             | D0-D7               | Operation                                     |
|-----|-----|-----|--------------------|---------------------|-----------------------------------------------|
| Н   | Н   | -   | nicht gültig       | nicht gültig        |                                               |
| L   | L   | Н   | gultig: Bits 8-15  | gultig: Bits 0-7    | Lesen eines Wortes                            |
| н   | L   | Н   | nicht gültig       | gültig: Bits 0-7    | Lesen eines Bytes<br>an ungerader Adresse     |
| L   | Н   | Н   | gù tig: Bits 8-15  | nicht gültig        | Lesen eines Bytes<br>an gerader Adresse       |
| L   | L   | L   | gültig: Bits 8-15  | gültig: B ts 0-7    | Schreiben eines Wortes                        |
| Н   | L   | L   | Kopie der Bits 0-7 | gültig: Bits 0-7    | Schreiben eines Bytes<br>an ungerader Adresse |
| L   | Н   | L   | gültig: Bits 8-15  | Kopie der Bits 8-15 | Schreiben eines Bytes<br>an gerader Adresse   |

Abb. 1.7: Kombinationstabelle der Signale  $R/\overline{W}$ ,  $\overline{UDS}$ ,  $\overline{LDS}$ 

Im Diagramm der Abb. 1.8 ist der Schreibvorgang eines Bytes schematisch dargestellt. Das Zurückkopieren wird bei dieser Darstellung ver nachlässigt, da diese Operation bei den jetzigen Generationen des 68000 nicht mehr vorgesehen ist.



Abb. 1.8: Adressierung von Bytes

DTACK Data Transfer ACKnowledge/Empfangsbestätigung der Datenübertragung

Dieses Signal gibt dem Mikroprozessor die folgende Information:

Beim Lesevorgang: Die zu lesenden Daten sind auf dem Bus verfügbar.

Beim Schreibvorgang: Die Daten sind von einem externen Baustein assi miliert worden.

# Steuersignale für die Zugehörigkeit der Busse: BR, BG, BGACK

Diese Signale bestimmen, welche der externen Bausteine die Steuerung der Busse kontrollieren oder kontrollieren werden. Diese drei Steuersignale heißen:

BR, BG, BGACK

## BR Bus Request/Busanfrage

Dieses Signal weist den Mikroprozessor darauf hin, daß eine andere intelligente Einheit auf die Busse zugreifen möchte.

## BG Bus Grant/Busfreigabe

Der anfragende Baustein wird durch dieses Signal darauf hingewiesen, daß der 68000 seine Anfrage  $\overline{BR}$  berucksichtigt hat. Die Umgebung des Mikroprozessors wird davon am Ende des ablaufenden Buszyklus informiert (der Begriff Buszyklus wird später erklärt).

# $\overline{\mathrm{BGACK}}$ Bus Grant ACKnowledge/Empfangsbestätigung des $\overline{BG}$

Der anfragende Baustein bestätigt die Übernahme der Busse und ihre Steuerung. Dieses Signal kann nicht bestätigt werden (BGACK im Low-Zustand), wenn nicht die folgenden 4 Voraussetzungen erfüllt sind:

- 1. BG wurde empfangen und bestätigt vom Mikroprozessor.
- 2 AS ist inaktiv, was besagt, daß der Mikroprozessor die Busse nicht benutzt.
- DTACK ist inaktiv, was besagt, daß kein Peripheriegerät oder externer Speicher mit dem zentralen Prozessor in Verbindung steht und die Busse benutzt.
- 4. BGACK ist inaktiv, also kein anderer intelligenter Baustein ist im Besitz der Buskontrolle.

Die Rolle dieser Signale ist also die rigorose Verwaltung des Multiprozessoren-Systems mit einer großen Störungsimmunität.

# Steuersignale der Unterbrechungen: IPL0, IPL1, IPL2 Interrupt Pending Level

Diese drei Eingänge vermitteln dem Mikroprozessor, daß ein Peripheriegerät eine Unterbrechung fordert. Die Prioritäten sind durch eine codierte Zahl geregelt. Die Zahl 7 repräsentiert dabei die höchste Priorität, während 0 darauf hinweist, daß keine Unterbrechung erwartet wird.

# Steuersignale des Systems: RESET, HALT, BERR

Diese Leitungen werden zur Initialisierung und zur Unterbrechung des Prozessors benötigt. Außerdem weisen sie auf die Fehler, die während eines Datenaustauschs aufgetreten sind, hin. Diese Signale sind:

# BERR, RESET, HALT

BERR Bus ERRor/Fehler auf dem Bus

Dieser Eingang informiert den Prozessor über ein Problem, das sich während des Zyklusablaufs ergeben hat. Dieses Problem kann beispielsweise sein:

- ein Peripherigerät, das dem Prozessor keine Antwort gibt;
- bei der Vergabe der Interrupt-Vektornummer ist ein Fehler aufgetreten;
- eine ungültige Adresse ist erzeugt worden usw.

Dieses Signal ist entweder von einer externen Logik generiert oder aber sofort vom teilnehmenden Baustein geliefert worden Zum Beispiel erzeugt der Baustein MC6841, eine Speicherverwaltungseinheit, ein FAULT-Signal, wenn ein nicht definiertes Segment angesprochen wird. In diesem Fall wird das FAULT-Signal sofort am BERR-Eingang des MC68000 angelegt.

#### RESET

Dieses Signal ist bidirektional.

Im Eingabemodus: Der Prozessor wird als Antwort auf ein externes Signal initialisiert.

Im Ausgabemodus: Die Ausführung des RESET-Befehls bewirkt die Zurücksetzung aller externen Bausteine in ihren Anfangszustand. In diesem Fall wird der Zustand des Prozessors nicht geändert.

Bemerkung: Die gesamte Initialisierung (Prozessor und externe Bausteine) wird durch die gleichzeitige Verwendung der Signale HALT und RESET auf den Eingangsanschlußstiften herbeigeführt.

## HALT

Dieses Signal ist ebenfalls bidirektional.

Im Eingabemodus: Wenn dieses Signal durch einen externen Baustein erzeugt wird, bringt es den Prozessor am Ende des aktuellen Buszyklus zum Stillstand. Alle Steuersignale werden inaktiv und alle Leitungen in den hochohmigen Zustand versetzt.

In Verbindung mit dem RESET-Signal bewirkt das HALT-Signal die Initialisierung des gesamten Systems.

Im Ausgabemodus: Der Prozessor unterbindet die Ausführung der Befehle, nachdem beispielsweise ein doppelter Fehler auf dem Bus festgelegt worden ist. Das HALT-Signal weist die Peripheriegeräte nun auf den Funktionsstillstand hin. Die einzige Möglichkeit, den HALT-Zustand zu verlassen, ist, einen Impuls auf der RESET-Leitung an den Prozessor auszusenden.

## Steuersignale der Peripheriegeräte der 6800-Serie: E, VPA, VMA

Diese Steuerleitungen ermöglichen die Schnittstellen-Verbindung zwischen den im Synchron-Modus arbeitenden Peripheriegeräten der 6800-Familie und dem MC68000; wir erinnern uns, daß der MC68000 im Asynchron-Modus arbeitet. Diese Signale heißen:

#### E, VPA, VMA

# E Enable/Freigabesignal (ist ein Ausgangssignal)

Dies ist das Standardsignal für die Kommunikation mit den 6800-Bausteinen. Es beansprucht die zehnfache Zeit wie der Eingangstakt des MC68000 und ermöglicht die Zusammenarbeit des MC68000 mit den Peripheriegeräten im Synchron-Modus.

# VPA Valid Peripheral Address/Gultige Peripherie-Adresse

Dieser Eingang bewirkt die Synchronisation des Datentransfers über E, wenn ein Peripheriegerät im Synchron-Modus mit dem Prozessor kommunizieren möchten. Gleichzeitig deutet dieses Signal darauf hin, daß sich der Prozessor in eine vektorielle Unterbrechung begibt.

# VMA Valid Memory Address/Gültige Speicheradresse

Ein Signal auf diesem Ausgang zeigt dem Peripheriebaustein der 6800-Familie, daß die Adresse auf dem Bus gültig ist und daß der MC68000 nun auf das E-Signal synchronisiert ist. Das Signal VMA stellt die Antwort auf das VPA-Signal dar.

# Betriebszustand des Prozessors: FC0, FC1, FC2 Function Code/Funktionscode

Diese drei Ausgänge deuten auf die Betriebszustände des Prozessors hin; er kann sich im Supervisor-Modus ("nicht beschränktes" System) oder im Anwender-Modus ("beschränktes" System) befinden. Außerdem weisen die drei Ausgänge auf den angewendeten Zyklustyp hin. Diese Information ist dann gültig, wenn das Signal  $\overline{AS}$  anliegt.

Die Funktionscodes ändern sich mit jedem Buszyklus. Sie werden vom Prozessor nach Untersuchung des S-Bits (Bit des Statusregisters) und in Übereinstimmung mit dem auszuführenden Buszyklus gesetzt:

Operandencode oder

Setzen der Funktionscodes FC0, FC1, FC2 in den "Programmzustand"
Supervisor-Programm, wenn S=1 ist
Anwender-Programm, wenn S=0 ist

Datensuche im Setzen der Funktionscodes FC0, FC1, FC2 in den "Datenzustand"
Supervisor-Daten, wenn S=1 ist
Anwender-Daten, wenn S=0 ist

#### Beispiel:



#### Tabelle der Funktionscodes:

| Zyklustyp                 | FC0 | FC1 | FC2 |
|---------------------------|-----|-----|-----|
| <br>reserviert            | L   | L   | L   |
| Anwender-Daten            | н   | L   | L   |
| Anwender-Programm         | L   | Н   | L   |
| reserviert                | Н   | H   | L   |
| reserviert                | L   | L   | Н   |
| Supervisor-Daten          | н   | L   | Н   |
| Supervisor-Programm       | L   | Н   | Н   |
| Interrupt ist aufgetreten | Н   | Н   | Н   |

## Anwendung dieser Funktionscodes:

Diese Codes kontrollieren beispielsweise die unterschiedlichen Zugriffsarten oder aber legen eine Differenzierung gewisser spezieller Zustände des Prozessors fest, wie etwa den Nachweis eines Interrupts (Unterbrechung).

# Beispiel für die Zugriffskontrolle:

Der Supervisor Speicher wird im Falle eines Anwenderzugriffs, wenn FC2=1 ist, dadurch geschützt, daß ein spezieller Supervisor-Bereich adressiert wird (Abb. 1.9).



Abb. 1.9: Speicherschutz

Ein weiteres Beispiel für die Gültigkeit des Speicherbereichs:

In diesem Fall wird die Bestätigung der verschiedenen Speicherbereiche über die Funktionscodes FC0, FC1, FC2 geregelt (Abb. 1.10).



Abb. 1.10: Beispiel für die Bestätigung der Speicherplatzbereiche



Abb. 1.11: Schaltung zur Unterbrechungsbestätigung mit Hilfe der Funktionscodes

Beispiel für den Zustand des Prozessors bei Auftreten eines Interrupts:

Wenn der Prozessor in die Phase der Interruptbestätigung eintritt, werden die Codes FC0, FC1, FC2 geändert und zur Erzeugung des Empfangsbestätigungssignals der Unterbrechung IACK verwendet (Abb. 1.11).

#### DER INTERNE AUFBAU DES MC68000

Zunächst wollen wir uns die Bedeutung der folgenden Fachbegriffe wieder ins Gedächtnis rufen:

- ein Byte 8 Bits
- ein Wort 16 Bits
- ein Langwort oder Doppelwort 32 Bits



Abb. 1.12. Interne Struktur des MC68000

Es folgt nun die Liste der Register unseres Mikroprozessors

8 32-Bit-Datenregister: D0, D1, ..., D7 - 8 32 Bit-Adreßregister: A0, A1, ..., A7

ein 32-Bit-Programmzähler: PCein 16-Bit-Statusregister: SR

Das Statusregister setzt sich aus zwei Bytes zusammen. Jedes Bit dieses Registers hat eine ganz bestimmte Bedeutung.

- Byte des niederwertigen Teils: Anwender-Byte
- Byte des höherwertigen Teils: System-Byte

Die interne Struktur des MC68000 ist durch das Schema der Abb. 1 12 dargestellt.

# Beschreibung des Statusregisters



Abb. 1.13: Struktur des Statusregisters

Bemerkung: Auf Anwenderebene kann nur in das Anwender-Byte geschrieben werden. Dagegen kann im Supervisor-Modus in das ganze Wort geschrieben werden.

## Bit T: Trace (Ablaufverfolgung)

Wenn dieses Bit gesetzt ist (T-1), befindet sich der Prozessor in der Betriebsart "Trace". Das bedeutet, daß das T-Bit nach jedem Befehl überprüft wird; wenn es den Wert 1 besitzt, wird zu einem vom Anwender geschriebenen Trace-Unterprogramm verzweigt. Dieses Trace-Unterprogramm kann zum Beispiel verwendet werden zur Prüfung des Inhalts von ausgewählten Registern oder Speicherplätzen, zur Statusprüfung oder zur Durchführung irgendwelcher anderer Fehlersuchaufgaben.

Ist das T-Bit nicht gesetzt, wird der nächstfolgende Befehl ausgeführt. Das Prinzip der Trace-Betriebsart wird in Abb. 1.14 gezeigt.



Abb. 1.14: Prinzip der Trace-Betriebsart

# Bit S: Supervisor (Überwachungs- oder System-Bit)

Dieses Bit definiert den Modus, in dem der Prozessor im weiteren arbeiten wird:

- Benutzerebene S=0
- Supervisor- oder Systemebene S=1

Der Supervisor-Modus unterliegt keinerlei Einschränkungen, weder in der Befehlsskala noch in adressierbaren Bereichen.

Dagegen ist der Anwender-Modus einschränkend:

Nicht alle Befehle sind erlaubt: Die sogenannten "privilegierten" Befehle sind verboten.

 Bestimmte Bereiche können nicht angesprochen werden. Beispielsweise ist das höherwertige Byte des Statusregisters SR nicht zugänglich; ebenso ist der Zugriff auf den Systemstapelzeiger SSP, Supervisor-Daten und -Programme verboten.

# Bits 12, 11, 10: Interrupt mask (Unterbrechungsmaske)

Diese drei Bits enthalten die Unterbrechungsmaske. Sie bestimmen die Prioritätsehene der Unterbrechungsanforderungen Die Unterbrechungen eines niedrigeren oder gleichwertigen Niveaus als das momentan gültige Unterbrechungsniveau bleiben jeweils unberücksichtigt. Nur die Unterbrechungen eines höheren Niveaus werden beachtet.

Es stehen 7 Prioritätsebenen zur Verfügung, wobei die Ebene 0 keine Priorität bedeutet, dagegen stellt das Niveau 7 die höchste Priorität dar.

Diese Masken werden automatisch während des Ablaufs der Unterbrechung gesetzt.

Mit Hilfe der folgenden Tabelle werden die Zustände dieser drei Bits sichtbar:

| EBENE | 12 | 11  | 10  |                                |
|-------|----|-----|-----|--------------------------------|
| 7     | 1  | 1   | 1   | → höchste Ebene, nur die nicht |
| 6     | 1  | 1   | 0   | maskierbaren Unterbrechungen   |
| 5     | 1  | 0   | - 1 | können ausgeführt werden       |
| 4     | 1  | 0   | 0   |                                |
| 3     | 0  | 1   | 1   |                                |
| 2     | 0  | - 1 | 0   |                                |
| 1     | 0  | 0   | 1   | → niedrigste Prioritätsebene   |
| 0     | 0  | 0   | 0   | → keinerlei Priorität          |

#### Bit N: Negative (Vorzeichen-Bit)

Dieses Bit wird auf 1 gesetzt, wenn eine arithmetische, logische, Schiebeoder Rotieroperation zu einem negativen Ergebnis führt Das N Bit entspricht also dem höchstwertigen Bit des Ergebnisses.

Bit Z: Zero (Null)

Dieses Bit wird auf 1 gesetzt, wenn das Ergebnis einer Operation 0 ist.

Bit V: oVerflow (Überlauf)

Dieses Bit wird gesetzt, wenn ein arithmetischer Überlauf auftritt; dies bedeutet, daß das Ergebnis die Länge des Operanden überschritten hat.

Bit C: Carry (Übertrag)

Dieses Bit wird auf 1 gesetzt, wenn bei einer Addition ein Ubertrag entsteht oder bei einer Subtraktion ein Entlehnwert benötigt wird.

Bit X: eXtend (Erweiterung)

Dieses Bit ist das Übertragsbit für Operationen mit erhöhter Genauigkeit. Im allgemeinen reflektiert es das C-Bit. Die Bedeutung des X-Bits wird am Anfang des Kapitels über Anwenderprogramme noch deutlich werden.

## Das Register A7

Die Adreßregister können als Basisadreßregister, Softwarezeiger zu benutzerdefinierten Speicherbereichen, zur temporären Aufnahme von Adreßwerten und für den Zugriff auf Bytes, Worte oder Doppelworte im Speicher dienen. Dabei fällt dem Register A7 eine ganz spezielle Rolle zu. Dieses Register übernimmt die Funktion des Stapelzeigers. Es dient der Sicherung der Rückkehradresse im Fall eines Unterprogrammaufrufs und während des Ablaufs von Fehlerprozeduren. Abhängig vom S-Bit ist entweder das Register A7 oder A7' aktiv.

Ist nämlich das S-Bit des Statusregisters 0, ist der Teil A7 des Registers aktiv, der den Benutzer-Stapelzeiger, USP (User Stack Pointer) genannt, darstellt. Wenn das S-Bit den Wert 1 besitzt, ist das Register A7' angesprochen; es handelt sich hierbei um den Supervisor-Stapelzeiger SSP (Supervisor Stack Pointer).

Im folgenden geben wir nun einige Definitionen, die Sie mit dem Grundbegriff des Zyklus vertraut machen sollen.

#### DIE ZYKLEN

#### Clock cycle/Taktzyklus

Darunter versteht man die Zeit, die zwischen zwei aufeinanderfolgenden gleichartigen Zuständen verstreicht Wenn das Eingangssignal 8 MHz besitzt, beträgt tzyk 125 ns.

#### Bus cycle/Buszyklus

Das ist die Zeit, die notwendig ist, um einen beliebigen Datenaustausch vorzunehmen:

- Lesen eines Bytes oder eines Wortes
- Schreiben eines Bytes oder eines Wortes
- Lesen/Ändern/Schreiben eines Bytes

Diese Zeit ist natürlich abhängig von den Zugriffszeiten der externen Bausteine.

#### Instruction cycle/Befehlszyklus

Hierbei handelt es sich um die Gesamtzeit, die benötigt wird, um die Durchführung eines Befehls zu verwirklichen: die Zeit der Buszyklen und die des Prozessors. Diese Zeitspanne ist abhängig vom Befehlstyp, den benötigten Buszyklen und dem "Prefetch"-Mechanismus ("Vorgriff"-Mechanismus), d. h manche Buszyklen werden vom Prozessor durch Vorziehen eines Befehls eingespart.

Der Beginn eines Befehlszyklus wird durch den Prozessor bestimmt und ist von seiner vorhergehenden Aktivität abhängig (Ende einer Datenübertragung, Ende einer internen Operation).

Im allgemeinen beanspruchen die Lese und Schreibvorgänge 4 Taktzyklen. Aber wenn ein Wartezustand eintritt, kann ein Zyklus auch langer dauern.

## Übungen

- 1.1: Wie viele Leitungen besitzt der Adreßbus?
- 1.2: Ist die Adresse eines Wortes gerade oder ungerade?
- 1.3: Hat das höherwertige Byte eines Wortes eine gerade oder eine ungerade Adresse?
- **1.4:** Welche Operation wird ausgeführt, wenn folgende Signale gesetzt sind:

$$\frac{R/\overline{W} = L}{\overline{UDS} = L}$$

$$\overline{LDS} = L$$

**1.5:** Welche Operation wird ausgeführt, wenn folgende Signale gesetzt sind:

$$R/\overline{W} = H$$

$$\overline{UDS} = H$$

$$\overline{LDS} = H$$

- **1.6:** Wie heißen die fünf Signale, die bei einer Datenübertragung im Asynchron-Modus eine Rolle spielen?
- 1.7: Welche Bedeutung hat das Signal BGACK?
- 1.8: Geben Sie die Anzahl der Datenregister an!
- 1.9: Geben Sie die Anzahl der Adreßregister an!
- 1.10: Wodurch wird deutlich, daß sich der Prozessor im Supervisor-Zustand befindet?

#### Lösungen

- 1.1: Der Adreßbus besitzt 23 Leitungen. Das Bit A0 ist durch UDS, LDS ersetzt worden.
- 1.2: Ein Wort beginnt immer mit einer geraden Adresse.
- 1.3: Das höherwertige Byte beginnt mit einer geraden Adresse, das niederwertige mit einer ungeraden.
- 1.4: Es wird ein Wort geschrieben:

 $R/\overline{W} = L$  Schreibvorgang

UDS = L höherwertiges Byte ist gesetzt

LDS = L niederwertiges Byte ist gesetzt

1.5: Ein Byte mit einer ungeraden Adresse wird gelesen:

 $R/\overline{W} = H$  Lesevorgang

UDS = H höherwertiges Byte ist nicht gesetzt

LDS = L niederwertiges Byte ist gesetzt

- 1.6: Die funf Signale, die im Asynchron-Modus eine Rolle spielen, heißen: R/W, AS, UDS, LDS, DTACK.
- 1.7: Wenn das Signal BGACK bestätigt worden ist, weiß der Prozessor, daß ein intelligenter Baustein die Steuerung der Busse übernommen hat.
- 1.8: Der 68000 besitzt 8 Datenregister: D0, .., D7.
- 1.9: Er besitzt 7 Adreßregister: A0, ..., A6.
- 1.10: Der Supervisor Modus wird intern durch Setzen des S-Bits manifestiert und nach außen hin durch den Inhalt der Funktionscodes FC0, FC1 und FC2 signalisiert.

Kapitel 2

# Allgemeine Organisation von Datenübertragungen

#### ÜBERTRAGUNGEN IM ASYNCHRON-MODUS

Dieser Übertragungstyp ermöglicht die Kommunikation zwischen dem 68000 und asynchronen Peripheriegeräten. Dadurch werden die Probleme, die durch die unterschiedlichen Zugriffszeiten der Bausteine entstehen, verringert, und Übertragungsfehler treten selten auf. In diesem Modus findet ein Dialog zwischen dem übergeordneten Baustein oder "Master" (Herr) und einem untergeordneten Baustein oder "Slave" (Sklave) statt. Fragen und Antworten kennzeichnen diesen Dialog. Das Hauptmerkmal dieses Übertragungstyps liegt darin, daß die Zeit in keinerlei Weise beschränkt ist.

In dem Fall, daß die Antwort ausbleibt, wird das System durch eine Alarmuhr (watch dog) benachrichtigt. Übertragungen im Asynchron Modus sind kontrollierbar, und bei Auftreten einer Unregelmäßigkeit kann eingegriffen werden: Adreßfehler, nicht vorhandene Adresse usw.

Schließlich erlaubt der Asynchron Modus auf einfache Weise die Kommunikation mit allen Bausteinen der 68000 Familie wie zum Beispiel dem 68451, einem Speicherbaustein.

#### LESEZYKLUS

Während des Lesens empfangt der Prozessor Daten aus dem Speicher oder von einem Peripheriegerät.

Er liest immer Bytes.

Wenn der Befehl eine Wortoperation beinhaltet, liest der Prozessor die zwei Bytes über den Bus, in dem Fall sind  $\overline{UDS} = 0$  und  $\overline{LDS} = 0$ .



Abb. 2.1: Organisatorischer Ablaufplan eines Lesevorgangs

Enthält der Befehl eine Byteoperation, dann benutzt der Prozessor das interne Bit A0, um zu bestimmen, welches Byte gelesen werden soll:

A0=0 dann sind 
$$\overline{UDS} = 0$$
 und  $\overline{LDS} = 1$ : gerades Byte  
A0=1 dann sind  $\overline{UDS} = 1$  und  $\overline{LDS} = 0$ : ungerades Byte

Um den zeitlichen Ablauf der Signale in einem Lesezyklus besser zu verstehen, betrachten Sie die Diagramme in Abb. 2.1 und 2.2.



Abb. 2.2: Zeitdiagramm: Lesen eines Wortes

# Erläuterung des Zeitdiagramms (Abb. 2.2)

#### Zustand SO.

- Der Adreßbus ist hochohmig.
- Der Funktionscode wird über FC0, FC1, FC2 angegeben.
- Das Signal R/W ist auf High gesetzt, damit der Lesevorgang beginnen kann.

#### Zustand S1:

- Die Adressen werden auf den Adreßbus gelegt.

#### Zustand S2:

- AS wird durch den Prozessor bestätigt (auf Low gesetzt), um darauf hinzuweisen, daß sich auf dem Adreßbus eine g
  ültige Adresse befindet.
- UDS, LDS werden ebenfalls gesetzt, je nachdem, was gelesen werden soll (Wort oder Byte).

#### Zustand S3:

 Der untergeordnete Baustein (Slave) wird über den Adreßbus und das Signal AS ausgewählt.

Dieser Baustein wertet R/W, UDS und LDS aus, um seine Information auf den Bus zu legen. Gleichzeitig bestätigt er DTACK (setzt es auf Low), um darauf hinzuweisen, daß die Daten auf dem Bus verfügbar sind. Dieses Signal muß ankommen, bevor der Zyklus S4 beendet 1st (beim 68000 L8: mindestens 20 ns vor dem Ende von S4; dies wird durch die "asynchronous setup time" (asynchrone Vorbereitungszeit) festgelegt. Sonst werden Wartezustände generiert (Swait).

#### Zustand S4:

Abtastung von DTACK.

#### Zustand \$5:

- Interne Synchronisierung von DTACK.

#### Zustand S6:

- Speichern der Daten in einem internen Register.

#### Zustand \$7:

- AS, UDS, LDS werden vom Prozessor gelöscht (auf High gesetzt).

Um jegliche Probleme einer schlechten Synchronisation auszuschalten, bleiben alle Adressen gesetzt. Das Signal R/ $\overline{W}$  und die Funktionscodes FC0, FC1, FC2 bleiben ebenfalls erhalten, um eine fehlerfreie Datenübertragung zu gewährleisten. Der untergeordnete Baustein gibt anschließend den Datenbus frei und löscht  $\overline{DTACK}$ , nachdem er die Löschung der Signale  $\overline{AS}$ ,  $\overline{LDS}$ ,  $\overline{UDS}$  erkannt hat. Auf diese Weise bleibt der Datenbus gesperrt, und auch das Signal  $\overline{DTACK}$  bleibt bis zum Eintreten der Zustände S0, S1 des nächsten Zyklus gelöscht

# Erzeugen von Wartezuständen Sw:

Wenn das Signal DTA  $\overline{CK}$  nicht vor dem Zustand S4 gesetzt wird, ersetzt der Prozessor die Zustände S5 und S6 durch Wartezustände Sw (Abb. 25). Diese Wartezustände treten paarweise auf. Zwei Sw-Zyklen entsprechen in der Version L8 128 ns. Wenn aber das Signal  $\overline{DTACK}$  überhaupt nicht empfangen wird, tritt eine Signaluhr in Kraft, die eine beliebige Unterbrechung oder das Signal  $\overline{BERR}$  (Busfehler) erzeugt.

Das genaue Zeitdiagramm eines Lesezyklus und die verschiedenen Zeitabstände sind in Abb. 2.3 und 2.4 dargestellt.

Es ist klar, daß einige Bausteine wie Speicher, Peripheriegeräte etc. nicht von sich aus das Signal  $\overline{DTACK}$  erzeugen können. Aus diesem Grund muß eine externe Logik geschaffen werden, die die Zeitintervalle vom Moment der Betätigung der Signale  $\overline{UDS}$ ,  $\overline{LDS}$  an zählt, und zwar abhängig von der Zugriffszeit des Bausteins.

Wenn die Übertragung zu Ende ist, werden UDS und LDS gelöscht, und der Generator von DTACK wird wieder auf Null gesetzt Wenn nach Ablauf einer gewissen Zeit das Signal DTACK nicht empfangen wird, meldet die Signaluhr einen Busfehler an den Prozessor. Das Schema der Abb. 2.6 stellt ein Beispiel zur Erzeugung des Signals DTACK dar.



#### BEMERKUNGEN

- 1 Die Vorbereitungszeit für die asynchronen Eingänge BGACK, TPT0 2 und VPA garantiert ihre korrekte Erkennung bei der nächsten fallenden Flanke des Taktsignals.
- BR muß zu diesem Zeitpunkt nur auf LOW gehen, damit sichergesteilt ist, daß es am Ende des Buszyklus erkannt wird.
- Den Zeitmessungen liegt ein High-Pegel von 2 Volt und ein Low-Pegel von 0,8 Volt zugrunde, wenn nicht anders angegeben

Abb. 2.3. Zeitdiagramm eines Lesezyklus

| Num.                                    |                                                        |                                | 4 MHz      |                  | 8 MHz    |                | BM            | Ha I           | 10 M         | IMZ L          | 12 5           | Unit |                                                  |
|-----------------------------------------|--------------------------------------------------------|--------------------------------|------------|------------------|----------|----------------|---------------|----------------|--------------|----------------|----------------|------|--------------------------------------------------|
| ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | Characteristic                                         | Symbol                         | ibol Min M |                  | Min      | Max            | Min           | Mex            | Min          | Мак            | Min            | Mex  | Unit                                             |
| <del>,  </del>                          | Clock Period                                           |                                | 250        | 500              | 167      | 500            | 125           | 500            | 100          | 500            | 80             | 250  | 775                                              |
|                                         | Clock Width Low                                        | tcyc                           | 115        | 250              | 75       | 250            | 55            | 250            | 45           | 250            | 36             | 125  | DS                                               |
|                                         |                                                        | ICL                            | 115        | 250              | 75       | 250            | 55            | 250            | 45           | 250            | 36             | 125  | DS.                                              |
|                                         | Clock Width High                                       | ICH                            |            | 10               | /2       | 10             | -             | 10             | ~            | 10             |                | 5    | PS                                               |
|                                         | Clock Fall Time                                        | ₹CI                            |            | 10               |          | 10             | $\overline{}$ | 10             |              | 10             | _              | 5    | ns.                                              |
| 5                                       | Clock Rise Time                                        | 1Cr                            | -          |                  |          |                |               |                |              |                |                | · 1. |                                                  |
| 6                                       | Clock Low to Address                                   | CLAV                           | -          | 90               |          | 80             |               | 70             |              | 60             | -              | 55   | ns<br>ns                                         |
| 6A                                      | Clack High to FC Vehid                                 | ICHECV                         | - :        | 90               |          | 80             |               | 70             | -            | 60             |                | 55   | ns .                                             |
| 7                                       | Clock High to Address Data<br>High Impedance (Maximum) | <sup>1</sup> CHAZ <sub>3</sub> |            | 120              | _        | 100            | -             | 80             | - ]          | 70             | -              | 60   | ns                                               |
| B                                       | Clock High to Address/FC<br>Invalid (Minimum)          | 1CHAZn                         | 0          |                  | 0        | -              | 0             | -              | ٥            | -              | 0              | -    | ns                                               |
| 91                                      | Clock High to AS DS Low<br>(Maximum)                   | 1CHSLx                         |            | 80               | -        | 70             |               | 60             | -            | 56             | _              | 56   | ns                                               |
| 10                                      | Clock High to AS, DS Law<br>(Minimum)                  | 1CHSLn                         | 0          | -                | 0        | -              | 0             | -              | 0            |                | 0              | -    | ns                                               |
| 112                                     | Address to AS DS (Read) Low/AS Write                   | 1AVSL                          | 55         | ~                | 35       |                | 30            | -              | 20           | -              | 0              |      | ns                                               |
| 11A <sup>2</sup> 7                      | FC Valid to AS, DS (Reed)<br>Low/AS Write              | trcvst                         | 80         |                  | 70       | -              | 60            | -              | 50           | -              | 40             | -    | กร                                               |
| 121                                     | Clock Low to AS, DS High                               | <sup>1</sup> CLSH              | -          | 90               |          | 80             | <u> </u>      | 70             |              | 55             | -              | 50   | n\$                                              |
| 132                                     | AS, DS High to Address/FC<br>Invalid                   | ISHAZ                          | 50         |                  | 40       |                | 30            |                | 20           |                | 10             | -    | rış                                              |
| 142,5                                   | AS, OS Width Low (Read) / AS<br>Write                  | ISL                            | 535        | -                | 337      | -              | 240           |                | 195          |                | 160            | -    | กร                                               |
| 14A2                                    | DS Width Low (Write)                                   | TOWPW                          | 285        |                  | 170      | -              | 115           | -              | 95           | -              | 80             | - 1  | ns.                                              |
| 152                                     | AS, DS Width High                                      | <sup>1</sup> SH                | 285        | -                | 180      | <del> </del>   | 150           | -              | 105          | -              | 65             | -    | ns.                                              |
| 16                                      | Clock High to AS DS High<br>Impedance                  | tCHSZ                          | -          | 120              |          | 100            |               | 80             | -            | 70             | -              | 80   | ns                                               |
| 172                                     | AS, DS High to R/W High                                | 1SHBH                          | 80         | 1 -              | 50       |                | 40            | -              | 20           | -              | 10             |      | ns                                               |
| 181                                     | Clock High to R/W High                                 | CHRHE                          | -          | 90               |          | 80             | -             | 70             |              | 60             |                | 80   | ng                                               |
| 19                                      | Clock High to 8/W High                                 | 1CHRHn                         | 0          | -                | 0        | -              | 0             | -              | 0            | -              | 0              |      | ns                                               |
| 201                                     | Clock High to F/W Low                                  | CHAL                           | -          | 90               | -        | 80             | -             | 70             | I -          | 60             | -              | 60   | กร                                               |
| ZUAB                                    | AS Low to R/W Valid                                    | 1ASRV                          | · ·        | 20               | 1 -      | 20             | <u> </u>      | 20             | -            | 20             | -              | 20   | ns                                               |
| 212                                     | Address Valid to R/W Low                               | TAVAL                          | 45         | <del>  -</del>   | 25       | 1              | 20            | <del>  -</del> | 0            | <del>  -</del> | 0              | 1 -  | กร                                               |
| 21AZ 7                                  | FC Valid to R/W Low                                    |                                | 80         | -                | 70       | +-             | 80            |                | 50           | <del> </del>   | 30             | 1    | P5                                               |
| 222                                     | R/W Low to DS Low (Write)                              | 1FCVRL                         | 200        | <del>  -</del> - | 140      | 1-             | 80            | 1 -            | 50           | <del>  -</del> | 10             | -    | ns                                               |
|                                         |                                                        | IRLSL                          |            |                  | -        | 80             | -             | 70             | -            | 56             | <del>  ~</del> | 55   | ns                                               |
| 23                                      | Clock Low to Data Out Valid<br>Clock High to R/W, VMA  | 1CLDO                          | ·          | 120              | -        | 100            | -             | 80             | -            | 70             | <del>  -</del> | 60   | ns                                               |
|                                         | High impedence                                         | 1                              | -          | -                | 40       |                | 30            |                | 20           | ┼              | 15             | 1-   | ns.                                              |
| 25 <sup>2</sup><br>26 <sup>2</sup>      | DS High to Data Out Invalid Data Out Valid to DS Low   | ISHDO                          | 55         | <del>  -</del>   | 35       | -              | 30            | ╁              | 20           | <del>-</del>   | 15             | -    | ns                                               |
| 276                                     | (Write) Data In to Clock Low (Setup                    | POICE                          | 30         | -                | 25       | -              | 15            | -              | 10           | -              | 10             | -    | ns                                               |
| 262.5                                   | Time) AS, DS High to DTACK High                        |                                | ò          | 490              | 10       | 325            | 10            | 245            | ō            | 190            | ō              | 150  | ns                                               |
| 29                                      | DS High to Data Invalid                                | 1SHDAH                         | 0          | -                | 0        | J25            | 0             | 240            | 0            | -              | 0              | -    | ns                                               |
|                                         | AS DS High to BERR High                                | 1                              | 0          | 1-               | 0        | <del>  -</del> | 0             | +              | ó            | +-             | 10             | 1    | ns                                               |
| 30                                      | ATTAIL                                                 | ISHBEH                         | <u> </u>   | +                | 1 "      | +              | +-            | +              | <del>Ľ</del> | +-             | Ť              | +    | <del>                                     </del> |
| 312.6                                   | (Setup Time)                                           | †DALD!                         | 1          | 180              | -        | 120            | <del> </del>  | 90             | -            | 86             | ↓-             | 50   | ns                                               |
| 37                                      | Fransition Time                                        | 1RH <sub>1</sub> (             | 0          | 200              | 0        | 200            | +             | 200            | 0            | 200            | +              | 200  | ns                                               |
| 33                                      | Clock High to BG Law                                   | LCHGL                          |            | 90               | <u> </u> | 80             | ~             | 70             | 1            | 80             | <del>  -</del> | 50   | ng                                               |
| 34                                      | Clock High to 8G High                                  | <sup>1</sup> CHGH              |            | 90               | <u> </u> | 80             | I -           | 70             | 1-           | 60             |                | 50   | ns                                               |
|                                         | BR Low to BG Low                                       | UBREGL                         |            | _                | 15       | 3.5            |               |                | 15           | 3.5            |                |      | Ch I                                             |
| 35                                      | 87 High to 86 High                                     |                                | 115        | 35               | 1.5      | 3.5            | 15            | 3.5            |              | 3 5            |                | 35   |                                                  |

Abb. 2.4: Lese- und Schreibzyklus (Spezifikationen)

| Num       | Characteristic                                    | Symbol              | 4.8  | AH2 | 6 MHz |     | \$ N | IHz | 10 8 | VHz. | 12.5 | MHz | Unit   |
|-----------|---------------------------------------------------|---------------------|------|-----|-------|-----|------|-----|------|------|------|-----|--------|
| reight i. |                                                   | Symoon              | Man  | Max | Milh  | Max | Min  | Мах | Min  | Ман  | Min  | Max | Unit   |
| 374       | BGACK Low to BR High<br>to Prevent Rea bitrations | <sup>I</sup> BGK BB | N)   |     | 25    |     | 20   |     | 20   |      | 20   | -   | ns     |
| 38        | BG Low to Bus High Impedance twith AS High!       | tGtZ                |      | 120 |       | 100 |      | 80  | -    | 70   |      | 60  | กร     |
| 39        | 8G Width High                                     | IGH                 | 15   | -   | 15    |     | 15   | _   | 1.5  |      | 15   |     | Clk Pa |
| 40        | Clack Law to VMA Law                              | ,CFAME              | -    | 90  | -     | 80  |      | 70  | -    | 70   |      | 70  | 05     |
| 41        | Clock Low to E Transition                         | tere                |      | 00  | -     | 85  |      | 70  |      | 56   |      | 45  | n\$    |
| 42        | E Output Pise and Fall Time                       | 1 <u>E</u> r, t     |      | 25  | -     | 25  |      | 25  |      | 25   |      | 25  | P1\$   |
| 43        | VMX Low to E High                                 | IVM_EH              | 325  |     | 240   |     | 200  |     | 150  |      | 90   | [ · | ns     |
| 44        | AS DS High to VPA Hir                             | 1SHVPH.             | 0    | 240 | 0     | 160 | 0    | 120 | 0    | 90   | 0    | 70  | ns     |
| 45        | E Low to Address VMA FL<br>Invalid                | 'Et A               | 55   |     | 36    | -   | 30   | -   | 10   | -    | 10   | -   | ns     |
| 46        | BGACK Width                                       | IBGL                | 1.5  |     | 15    |     | 15   |     | 15   |      | 1.5  | _   | Clk Pe |
| 476       | Asynchronous Input Setup Time                     | IASI                | 30   | -   | 25    |     | 20   | -   | 20   | -    | 20   | -   | ns     |
| 483       | BEAR LOW to DTACK LOW                             | BELDAL              | 30   | -   | 25    |     | 20   | -   | 20   | T-   | 20   | -   | ns     |
| 49        | £ Low to AS DS Invalid                            | ELS                 | 80   |     | - 80  |     | 80   | -   | - 80 |      | - 80 | -   | ns     |
| 50        | E Width High                                      | 184                 | 900  |     | 600   |     | 450  | -   | 350  |      | 280  | -   | ns     |
| 51        | E Width Low                                       | te L                | 1400 |     | 900   |     | 700  | -   | 550  | -    | 440  | -   | ns     |
| 52        | E Extended Rise Time                              | 1CIEHX              |      | 80  |       | 80  |      | 80  | -    | 80   | T -  | 80  | ns     |
| 53        | Data Hold from Clock High                         | 1CHD0               | 0    |     | 0     | -   | Ö    | -   | 0    | 1 -  | 0    | -   | ns     |
| 54        | Data Hold from E Low (Write)                      | 1EL DOZ             | 60   | -   | 40    | -   | 30   | -   | 20   | -    | 15   | -   | (1)S   |
| 55        | R/W to Data Bus Impedance<br>Change               | 'RLDO               | 55   | -   | 35    | -   | 30   | -   | 20   | -    | 10   |     | ns     |
| 564       | HALT/RESET Pulse Width                            | HRPW                | 10   |     | 10    | -   | 10   |     | 10   | 1 -  | 10   | -   | Clk Pe |

Abb. 2.4: Lese- und Schreibzyklus (Fortsetzung)



Abb. 2.5. Zeitdiagramm eines Lesezyklus mit Erzeugen von Wartezuständen



Abb. 2.6: Beispiel zur Erzeugung des Signals DTACK

### **SCHREIBZYKLUS**

Während eines Schreibzyklus sendet der Prozessor Daten zu einem Speicher oder Peripheriegerät. In jedem Fall schreibt der Prozessor Bytes. Wenn der Befehl eine Wort-Operation enthält, schreibt der Prozessor zwei Bytes. Beinhaltet der Befehl eine Byte-Operation, benutzt der Prozessor das interne Bit A0, um festzustellen, in welche Adresse er schreiben soll und welche entsprechenden Signale er setzen soll.

Wenn A0=0, dann setze  $\overline{UDS} = 0$  und LDS - 1: Schreiben eines Bytes an eine gerade Adresse.

Wenn A0-1, dann setze  $\overline{UDS} = 1$  und  $\overline{LDS} = 0$ : Schreiben eines Bytes an eine ungerade Adresse.

Wir wollen nun einen Schreibzyklus anhand der Schemazeichnung Abb. 2.7 und des Zeitdiagramms Abb. 2.8 untersuchen.



Abb. 2.7: Schemazeichnung eines Lesezyklus



Abb 2.8: Zeitdiagramm eines Lesezyklus

# Erläuterung des Zeitdiagramms (Abb. 2.8)

### Zustand S0:

- Der Adreßbus ist hochohmig.
- Die Funktionscodes werden über FC0, FC1, FC2 ausgegeben.

### Zustand S1.

- Die Adressen werden auf den Adreßbus gelegt.

### Zustand S2:

- AS wird bestätigt, um darauf hinzuweisen, daß sich auf dem Adreßbus eine gültige Adresse befindet.
   Der Peripheriebaustein oder der Speicher wird über den Adreßbus und AS angewählt.
- Das Signal R/W ist f
  ür den Schreibvorgang gesetzt (low).

#### Zustand S3:

- Der Prozessor legt die Daten auf den Bus.

## Zustand S4:

- Die Signale  $\overline{UDS}$  und  $\overline{LDS}$  werden gesetzt:  $\overline{UDS}$  und/oder  $\overline{LDS}$ =0.

Der angewählte Baustein verwendet das Signal  $R/\overline{W}$  sowie  $\overline{UDS}$  und  $\overline{LDS}$ , um dem Datenbus die Information zu entnehmen. Nachdem er die Daten gespeichert hat, bestätigt er das Signal  $\overline{DTACK}$ . Wie beim Lesezyklus muß  $\overline{DTACK}$  vor dem Ende des Zustands S4 empfangen werden, sonst wird ein Wartezustand erzeugt.

### Zustand S5:

Interne Synchronisierung des Signals DTACK

#### Zustand S6:

- Stabiler Zustand.

### Zustand S7:

- Die Signale AS, UDS, LDS werden gelöscht (auf High gesetzt).

Die Werte auf dem Daten- und Adreßbus bleiben gültig. Das Signal R/ $\overline{W}$  bleibt ebenfalls aufrechterhalten, um eine fehlerfreie Datenübertragung



### BEMERKUNGEN

- 1 Bei Zeitmessungen wird ein Low-Pegel von 0,8 Volt und ein High-Pegel von 2,0 Volt vorausgesetzt, wenn nicht ausdrucklich anders erwähnt
- 2 Es ist möglich, daß R/W erst nach AS gultig wird, obwohl beide von der steigenden Flanke von S2 gesteuert werden.

Abb. 2.9: Zeitdiagramm eines Schreibzyklus

zu gewährleisten. Der untergeordnete Baustein (Slave) betrachtet DTACK so lange als gesetzt, bis er die Löschung des Signals AS oder UDS, LDS wahrnimmt. Anschließend löscht er dann nach einem gewissen Zeitintervall das Signal DTACK. Zum Schluß gibt der Prozessor am Ende von S7 oder während des Zustands S0 des darauffolgenden Zyklus die Busse frei. Das genaue Zeitdiagramm eines Schreibzyklus ist in Abb. 2.9 zu sehen.

# LESE-/ÄNDERUNGS-/SCHREIBZYKLUS

Der Lese-/Änderungs-/Schreibzyklus realisiert einen Lesevorgang, ändert die Daten in der arithmetisch-logischen Einheit (ALU) und schreibt die Daten an die gleiche Adresse, an der sie gelesen wurden. Das Signal  $\overline{AS}$  bleibt während der 3 Phasen Lesen, Ändern und Schreiben gültig, so daß eine Unterbrechung dieses Zyklus unmöglich ist.

Der Befehl TAS (Test And Set), Testen und Setzen des höchstwertigen Bits des Bytes, ist der einzige, der diesen Zyklustyp verwendet. Er ermöglicht das Zugreifen auf gemeinsame Datenfelder in Multiprozessorsystemen.

Der Befehl TAS ist eine Byte-Operation, was eine Bestätigung dafür ist, daß Lese-/Anderungs-/Schreibzyklen stets Byte-Operationen sind. Da während der Datenübertragung das Signal AS gesetzt ist, kann eine andere Busanfrage erst nach Beendigung des TAS-Befehls berücksichtigt werden.

Dieser Zyklustyp dauert mindestens 10 Takte (20 Zustände) Die Bedeutung dieses Zyklus wird Ihnen nach näherer Betrachtung des Befehls TAS in der Befehlsübersicht noch klarer werden. Die Schemazeichnung des Lese-/Änderungs-/Schreibzyklus ist in Abb. 2.10 dargestellt und das zugehörige Zeitdiagramm in Abb. 2.11.

# Erläuterung des Zeitdiagramms (Abb. 2.11)

Bis zum Zustand S6 wird ein normaler Lesezyklus ausgeführt.

### Zustand S7:

- UDS und LDS werden gelöscht.

Der Adreßbus, AS, R/W und die Funktionscodes bleiben bei der Vorbereitung des Schreibvorgangs unverändert.
 DTACK wird vom untergeordneten Baustein nach dem Löschen von UDS und LDS ebenfalls gelöscht.

### Zustand S8:

- Die interne Änderung der Daten kann also durchgeführt werden.

Keine Änderung der Steuersignale.

 Das Signal R/W bleibt bis zum Eintreten des Zustands S14 auf High gesetzt, um Buskonflikte mit dem vorhergegangenen Lesevorgang zu vermeiden.

### Zustände S9 bis S13:

- Keine Änderung der Steuersignale.

### Zustand \$14:

 Das Signal R/W wird für den Schreibvorgang gesetzt (low). Dieser Zustand ist gleichbedeutend mit dem Zustand S2 eines normalen Schreibvorgangs.

### Zustand \$15:

 Die Daten werden auf den Bus gelegt. Der Zustand ist aquivalent zum Zustand S3 des normalen Schreibvorgangs.

### Zustand \$16:

UDS und LDS werden bestätigt, um anzuzeigen, daß der Datenbus in einem stabilen Zustand ist.

 Das Signal DTACK wird erwartet, das vor Beendigung des Zustands S16 empfangen werden muß (sonst wird Sw erzeugt). Dieser Zustand ist mit Zustand S4 des normalen Schreibvorgangs zu vergleichen.

## Zustände S17, S18

- Gleichbedeutend mit S5, S6.

### Zustand \$19:

- Gleichbedeutend mit S7.



Abb. 2.10: Organisatorischer Ablauf des Lese-/Anderungs-/Schreibzyklus



Abb. 2.11: Zeitdiagramm des Lese-Anderungs-Schreibzyklus

# ZYKLUSSTÖRUNGEN

In einer Busarchitektur, die aufgrund eines Dialogsystems mit einem externen Baustein funktioniert, kann es vorkommen, daß das Frage-Ant wortspiel nicht zustandekommt. Es ist dann notwendig, daß eine externe Logik eingeschaltet wird, eine Signaluhr, die im Notfall einen Fehler auf dem Bus meldet:  $\overline{BERR}$ .

BERR (Bus ERRor) tritt immer auf, wenn es bei einer Datenübertragung zu einer Anomalie kommt z. B.:

- Baustein antwortet nicht
- Baustein nicht vorhanden
- Baustein für Fehlerwahrnehmung und -berichtigung meldet sich (68653)

Seite nicht vorhanden (bei virtueller Adressierung)

Wenn der Prozessor das Signal BERR erhält, hat er zwei Möglichkeiten:

- 1. Einleitung einer Ausnahmeprozedur: Ausfuhrung des Programms, das das Auftreten eines Busfehlers behandelt.
- 2. Den Buszyklus von neuem aktivieren.

## Die Ausnahmeprozedur

Ist das Signal  $\overline{BERR}$  bestätigt worden, wird der ablaufende Buszyklus unterbrochen. Adreß- und Datenbus bleiben so lange hochohmig, wie das Signal  $\overline{BERR}$  gesetzt bleibt. Wenn  $\overline{BERR}$  gelöscht wird, leitet der Prozessor seine "Rettungsprozedur" ein, die zunächst gewisse Informationen auf den Stapel legt.

Die Ausnahmeprozedur für einen Bussehler ist fast die gleiche wie die einer autovektoriellen Unterbrechung (Unterbrechung, deren Vektornummer automatisch vom Prozessor errechnet wird).

# Diese Prozedur arheitet wie folgt:

- Retten des Programmzeigers (PC) und des Statusregisters (SR) auf den Stapel.
- Retten der Fehlerbezeichnung, um den Fehler zu bestimmen (dies ist eine zusätzliche Aktion im Vergleich zur Unterbrechung).
- Ablesen der Adresse des Fehlerprogramms auf dem Bus, die sich in der Ausnahmevektortabelle an der Adresse des Signals BERR (\$000008) befindet.
- Ausführen des Programms, das dieser Ausnahme entspricht.

Eine genauere Untersuchung von BERR wird im Kapitel über die Ausnahmen durchgeführt.

Die Reaktionen der Steuersignale im Falle des Auftretens von  $\overline{BERR}$  sind im Zeitdiagramm der Abb. 2.12 dargestellt.



Abb. 2.12: Zeitdiagramm bei Auftreten eines Busfehlers

## Wiederaufnahme des Zyklus auf dem Bus (Re-run)

Erhält der Prozessor während des Buszyklus das Signal BERR und ist HALT durch einen externen Baustein aktiviert worden, dann beginnt der Prozessor noch einmal den gleichen Zyklus.

Zunächst jedoch unterbricht er beim Empfang dieser beiden Signale den gerade ablaufenden Zyklus und versetzt den Adreß- und den Datenbus in den hochohmigen Zustand. Die Signale AS, UDS und LDS werden inaktiv. Danach bleibt der Prozessor maktiv, bis das HALT-Signal von dem externen Baustein auf inaktiv gesetzt wird.

Nun startet der Prozessor den Buszyklus von neuem, indem er die gleichen Daten (bei einer Schreiboperation) und die gleichen Steuersignale verwendet. Das Signal BERR muß mindestens einen Takt vor dem Löschen des HALT Signals deaktiviert worden sein.

Bemerkung: Der Prozessor führt kein Re-run während eines Lese-/Änderungs-/Schreibzyklus durch. In der Tat muß bei diesem Operationstyp der Schreibvorgang ausgeführt werden, ohne daß das Signal AS seit dem zugehörigen Lesevorgang geändert wurde. Dies ist natürlich nicht möglich, wenn der Prozessor eine Wiederaufnahme des Zyklus durchführt.



Abb. 2.13: Zeitdiagramm eines Wiederaufnahmezyklus (Re-run)

Der MC68000 erzeugt also einen Busfehler, wenn die Signale BERR und HALT während eines Lese-/Änderungs /Schreibzyklus gesetzt werden.

Mit Hilfe des Zeitdiagramms in Abb. 2.13 untersuchen wir eine Wiederaufnahme.

Es muß erwähnt werden, daß das Signal HALT ebenfalls verwendet wird, um den "Einzelschrittmodus" zu generieren, der bei der Fehlerbeseitigung in Programmen behilflich sein kann, und daß zwei aufeinanderfolgende Busfehler einen "doppelten Busfehler" ergeben.

Alle diese Fälle werden später in diesem Kapitel und im Kapitel über Aus nahmen besprochen.

Bevor wir die Betrachtungen über Zyklusstörungen abschließen, fassen wir noch einmal die moglichen Aktionen der Signale DTACK, BERR und HALT mit Hilfe der Tabellen in Abb. 2.14 und 2.15 zusammen.

| AKTION                                                            | SIGNALE  DTACK kommt als erstes Signal an                                                                                      |  |  |
|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|
| Normales Zyklusende und Übergang zum<br>folgenden Zyklus          |                                                                                                                                |  |  |
| Normales Zyklusende und Stillstand;<br>danach Neustart gemäß HALT | HALT kommit vor oder zur gleichen Zeit wie DTACK an                                                                            |  |  |
| Zyk us unterbrochen und Verarbeitung der Ausnahme Busfehler       | BERR bestätigt vor oder zur gleichen Zeit<br>wie DTACK und BERR verneint zur gleicher<br>Zeit oder nach der Negation von DTACK |  |  |
| Zyklus unterbrochen und neu gestartet                             | HALT und BERR bestätigt zur gleichen Zeit oder vor DTACK HALT verneint wenigstens einen Zyklus nach BERR                       |  |  |

Abb. 2.14. Die verschiedenen Moglichkeiten, einen Zyklus zu beenden

Bemerkung: BERR, DIACK HALT müssen an der steigenden Flanke des Eingangstaktes bestätigt oder verneint werden, damit die Signale im gleichen Zustand stabil sind.

Die Art und Weise, wie diese Signale verneint werden, ist ebenfalls sehr wichtig und wird in der Tabelle der Abb. 2.16 dargestellt.

| FALL-Nr | SIGNALE | BESTÄTIGT AN DER GRENZE<br>DES ZUSTANDS |     | ERGEBNISSE                  |
|---------|---------|-----------------------------------------|-----|-----------------------------|
|         |         | N                                       | N+2 |                             |
|         | DTACK   | A                                       | BA  |                             |
| 1       | BERR    | NA                                      | X   | normales Zyklusende         |
|         | HALT    | NA                                      | X   |                             |
|         | DTACK   | Α                                       | ВА  | normales Zyklusende         |
| 2       | BERR    | NA                                      | X   | Stillstand und Wiederbeginn |
|         | HALT    | A                                       | BA  | nach Negation von HALT      |
|         | DTACK   | NA                                      | A   | normales Zyklusende         |
| 3       | BERR    | NA                                      | NA  | Stillstand und Wiederbeginn |
|         | HALT    | A                                       | BA  | nach Negation von HALT      |
|         | DTACK   | X                                       | Х   | Zyklus unterbrochen und     |
| 4       | BERR    | A                                       | BA  | Verarbeitung der            |
|         | HALT    | NA                                      | NA  | Ausnahme BERR               |
|         | DTACK   | х                                       | Х   | Zyklus unterbrochen und     |
| 5       | BERA    | Α                                       | BA  | Neustart des Zyklus         |
|         | HALT    | NA                                      | Α   |                             |
|         | DTACK   | х                                       | Х   | Zyklus unterbrochen und     |
| 6       | BERR    | A                                       | BA  | Neustart des Zyklus         |
|         | HALT    | A                                       | BA  |                             |
|         | DTACK   | NA                                      | Х   | Zyklus unterbrochen und     |
| 7       | BERA    | NA                                      | A   | Neustart wenn HALT          |
|         | HALT    | A                                       | BA  | verneintist                 |

A = aktiv NA = nicht aktiv BA = bleibt akt v X = gleichgültig

Abb. 2.15: Tabelle der Kombinationen der Signale  $\overline{DTACK}$ ,  $\overline{BERR}$ ,  $\overline{HALT}$ 

# Beispiele für Zyklusunterbrechungen

# Beispiel A:

Ein Decodier-Baustein sendet ein Signal, wenn ein nicht vorhandenes Feld angesprochen wird. In dieser Situation kann er unter anderem BERR und DTACK gleichzeitig aktivieren, um eine Ausnahmeprozedur "Busfehler" zu erzeugen.

| SITUATIONEN<br>VERURSACHT<br>DURCH DIE | SIGNALE | NEGATION AN DER STEIGENDEN<br>FLANKE DES ZUSTANDS |     | KONSEQUENZ FÜR DEN<br>NÄCHSTEN ZYKLUS  |
|----------------------------------------|---------|---------------------------------------------------|-----|----------------------------------------|
| SIGNALBE<br>STÄTIGUNGEN                |         | N                                                 | N+2 |                                        |
| Normal                                 | BERR    | N                                                 | _   | kann den Buszyklus                     |
|                                        | HALT    | N                                                 | N   | verlängern                             |
| Normal                                 | BERR    | _                                                 | N   | Wenn der Buszyklus be                  |
|                                        | HALT    | N                                                 | -   | gonnen ist, gibt es<br>einen Busfehler |
| Busfehler                              | BERR    | N                                                 | N   | Ausnahme BERR                          |
|                                        | HALT    | N                                                 | N   |                                        |
| Neustart                               | BERR    | N                                                 | N   | illegal, Verzweigung                   |
|                                        | HALT    | N                                                 |     | zum Vektor Nr. 0                       |
|                                        | BERR    | N                                                 | _   | Neustart des                           |
|                                        | HALT    |                                                   | N   | Buszyklus                              |

N: Negation der Signale im dargesteilten Zustand

Abb. 2.16. Tabelle der möglichen BERR, HALT

# Beispiel B.

Ein Warnsystem, das fehlerhafte Daten in einem Speicherplatz feststellt, sendet ein Signal. Das System wartet, bis die Daten überprüft worden sind, bevor  $\overline{DTACK}$  aktiviert wird:

- sind die Daten fehlerfrei, wird DTACK aktiviert;
- sind die Daten fehlerhaft, werden gleichzeitig BERR und HALT aktiviert, so daß der Zyklus von neuem beginnt.

# Beispiel C:

Wir gehen wieder von demselben System aus, das wartet, bis die Daten überprüft worden sind, bevor DTACK aktiviert wird:

- sind die Daten fehlerfrei, wird DTACK aktiviert;
- sind die Daten fehlerhaft, werden BERR und DTACK aktiviert, um eine Ausnahmeprozedur "Busfehler" einzuleiten.

Bevor wir zur Aufzählung der unterschiedlichen Funktionen des Signals HALT übergehen, wollen wir noch einmal in einer Tabelle das Zusammenspiel der Signale BERR und HALT verdeutlichen.



Abb. 2 17: Zusammenspiel der Signale BERR und HALT

# WEITERE FUNKTIONEN DES SIGNALS HALT

Zunächst einmal rufen wir uns in Erinnerung, daß der Anschluß HALT bidirektional ist. Wenn wir ihn als Eingang betrachten, können die folgenden Fälle auftreten:

- HALT zusammen mit BERR bewirkt die Wiederholung des Buszyklus.
- HALT zusammen mit RESET: bewirkt den Neustart des Systems.
- HALT alleine: bewirkt den Stillstand des Prozessors.

HALT alleine bewirkt den Stillstand des Prozessors, nachdem der laufende Buszyklus beendet ist; die Steuersignale sind in diesem Fall inaktiv (AS, UDS, LDS, R/W).

Die Tristate-Leitungen sind hochohmig. Dennoch werden die Bus-Anforderungen berücksichtigt; die Signale  $\overline{BR}$ ,  $\overline{BG}$  und  $\overline{BGACK}$  bleiben gültig.

Wenn man diesen Anschlußstift (HALT) als Ausgang betrachtet, wird er aktiviert, wenn der Prozessor nach einem Doppelbusfehler zum Stillstand kommt, damit die externen Schaltungen auf diesen Zustand aufmerksam werden. RESET wird den Mikroprozessor von neuem starten.

### Der Einzelschritt-Modus

Die Verwendung des Signals HALT ermöglicht den Ablauf des Buszyklus im Einzelschritt-Modus.

Der Prozessor führt einen Buszyklus aus, kommt zum Stillstand, bearbeitet dann den nächsten Buszyklus usw.

Das Prinzip des Einzelschritt Modus wird mit Hilfe der Abb. 2.18 verdeutlicht.

Bei diesem Schema fällt auf, daß die Leitung, die mit normal/Einzelschritt beschriftet ist, beim normalen Ablauf auf 0 und im Einzelschritt-Modus auf 1 gesetzt ist. Auf diese Weise wird im Normalmodus, unabhängig vom zweiten Teil der Logik, kein einziges Signal HALT erzeugt. Im Einzelschritt-Modus ist dies vom Signal AS und dem Zustand des Schalters S2 abhängig. Sobald AS aktiv ist, besitzt der Ausgang Q des Flip-Flops den Wert 1, und das Signal HALT geht auf Low (aktiv). Wenn sich S2 im Wartezustand befindet, verändert sich der Zustand des Flip-Flops nicht, der Prozessor bleibt gestoppt. Geht S2 jedoch in den Einzelschritt-Modus über, wird der Ausgang Q auf 1 gesetzt, und das Signal HALT ist von neuem aktiv.



Abb. 2.18: Schaltung zur Realisierung des Einzelschritt-Betriebs

Das Zeitdiagramm (Abb. 2.19) macht diesen Ablauf deutlich.



Abb. 2.19 Zeitdiagramm der Signale im Einzelschritt-Modus

# Asynchrone Datenübertragung

Um im Asynchron-Modus die Steuerung des Buszyklus schrittweise zu betreiben, genugt es, das Signal  $\overline{DTACK}$  um eine bestimmte Zeit T zu verzögern. Auf diese Weise wird der Prozessor Wartezustände Swerzeugen, bis  $\overline{DTACK}$  empfangen wird. Somit kann der Benutzer ungehindert den Zustand der Signale im Buszyklus untersuchen, bis er beispielsweise durch einen Knopfdruck das Signal  $\overline{DTACK}$  sendet.



Abb. 2.20. Ubersicht des Eingriffs in das DTACK-Signal



- S1 offen i normale Durchführung
- S1 . gesch ossen Einzelschritt-Modus
- S2 einmal hin und hergeschaltet bewirkt die Generierung eines Signals DTACK

Abb. 2.21. Logik zur Realisierung des Einzelschritt-Modus durch Eingriff in das DTACK-Signal

Es ist klar, daß in einer solchen Anwendung keine Zeitüberwachungsschaltung ("Watchdog") den Zyklus stören darf.

Die schematische Darstellung dieses Verfahrens ist in den Abb. 2.20 bis 2 22 zu finden.



Abb. 2.22 Zeitdiagramm des Eingriffs in das DTACK-Signal

# SYNCHRONE DATENÜBERTRAGUNG

Bei diesem Übertragungstyp gibt es keinen Dialog zwischen der übergeordneten Schaltung ("Master") und der untergeordneten ("Slave"). Jedes Signal muß zwangsläufig innerhalb einer bestimmten Zeitspanne, die vom Prozessor festgelegt wird, eintreffen. Dieser Ablauf wird in dem Schema der Abb. 2.23 veranschaulicht.

Die gebräuchlichsten Peripheriebausteine aus der Familie des 6800 sind:

- 6821 Peripheral Interface Adapter (PIA)
  Universeller Parallel-Interface Baustein
- 6840 Programmable Timer (PTM) Zeitgeberbaustein
- 6843 Steuerbaustein für Diskettenkontroller
- 6845 CRT-Controller (CRTC) Steuerbaustein für Bildschirme
- 6850 Asynchronous Communications Interface Adapter (ACIA)
  Asynchroner Datenübertragungsbaustein (UART)
- 6852 Synchronous Serial Data Adapter (SSDA) Synchroner Datenübertragungsbaustein



Abb. 2.23: Ablaufschema einer synchronen Datenübertragung

Um Daten zwischen dem MC68000 und einem Peripheriebaustein der 6800-Familie übertragen zu können, sind drei Steuersignale vorhanden:

E (Enable) – Freigabe VPA (Valid Peripheral Address) – gültige Peripherieadresse VMA (Valid Memory Address) – gültige Speicheradresse

Das Freigabesignal E entspricht dem E- oder Phi2-Signal des 6800-Systems. Dieser Takt wird von den 6800-Periphenebausteinen verwendet, um den Datentransfer zu synchronisieren.

E ist ein Takt, der mit einer Frequenz von einem Zehntel des 68000-Systemtakts läuft. Die Taktperiode von E entspricht also 10 Taktperioden des 68000 mit – im Low-Zustand – 6 Taktperioden des Signals CLK und – im High-Zustand 4 Taktperioden des Signals CLK (Abb. 2.24).



Abb. 2.24: Der E-Takt

# Beispiel:

Im Falle des MC68000L8 hat der Takt eine Frequenz von 8 MHz und E etwa 0,8 MHz. Dies erlaubt also, die Peripheriebausteine der 1-MHz-Skala mit einem MC68000L8 zu verbinden.

Wir wollen uns nun das Zeitdiagramm für die synchrone Datenübertragung genauer anschauen.

# Erläuterung des Zeitdiagramms (Abb. 2.25)

Erster Buszyklus: Lesezyklus im asynchronen Modus Zweiter Buszyklus: Lesezyklus mit einem peripheren 6800-Baustein

#### Zustand S0:

- Der Adreßbus ist in hochohmigem Zustand.
- Die Funktionscodes sind gesetzt.

### Zustand S1:

- Eine Adresse wird auf den Adreßbus gelegt.



Abb. 2.25: Zeitdiagramm eines synchronen Zyklus

### Zustand S2:

- AS wird aktiv, um anzugeben, daß sich eine gültige Adresse auf dem Bus befindet.
- UDS und LDS sind ebenfalls aktiv.

### Zustände S3...Sw...S5:

Der Prozessor, der das VPA-Signal empfangen hat, weiß, daß ein synchroner Baustein adressiert wurde und daß die Operation durch das Freigabesignal E synchronisiert werden soll. Er wartet, bis E auf High gesetzt ist – evtl indem er Wartezustände erzeugt –, um dann VMA zu aktivieren (low).

Das Signal VMA wird nun zur Selektion des peripheren Bausteins verwendet.

Während E auf High ist, stellt der Peripheriebaustein die zu lesende Information auf dem Datenbus zur Verfügung.

### Zustand S6:

- Der Prozessor speichert die Daten

### Zustand S7:

AS, UDS, LDS werden vom Prozessor zurückgesetzt (inaktiv, high).

Das Signal E geht auf Low.

- Im nachsten Schritt wird der Adreßbus wieder in den hochohmigen Zustand versetzt.
- Die externe Logik setzt schließlich VPA zurück auf High (in einer Taktperiode), nachdem das Signal AS zurückgesetzt worden ist (auf High).

Dritter Buszyklus: Schreibzyklus mit einem peripheren 6800-Baustein

### Zustand S0.

- Der Adreßbus ist in hochohmigem Zustand.
- Die Funktionsgodes sind gesetzt

### Zustand S1:

- Eine Adresse wird auf den Adreßbus gelegt.

### Zustand S2:

- $\overline{AS}$  wird bestätigt (low, aktiv), um anzugeben, daß sich eine gultige Adresse auf dem Bus befindet.
- R/W wird für den Schreibvorgang gesetzt (low).

### Zustand S3:

- Die zu schreibenden Daten werden auf den Bus gelegt.

## Zustand S4.

- UDS, LDS werden bestätigt, um anzuzeigen, daß die sich auf dem Bus befindenden Daten gültig sind.

# Zustände S5...Sw...S6:

 Der Prozessor hat das Signal VPA empfangen, kurz nachdem E auf Low gefallen ist und vor dem Eintreten des Zustands S4. Nach dem Empfang von VPA sendet der Prozessor VMA zum Peripheriebaustein. Die Daten werden während des High-Zustands von E angenommen.

### Zustand S7:

- R/W wird wieder auf High gesetzt.
- Der Datenbus wird hochohmig.
- Die externe Logik setzt VPA auf High zurück, sobald AS auf High zurückgesetzt worden ist.

Die Zeitdiagramme in Abb. 2.26 und 2.27 zeigen die Synchronisierungsprobleme im synchronen Modus.



Günstigsler Fall: VPA kommt vor dem Ende von S4 an, die Setup-Zeit (47) wird berücksichtigt Abb. 2.26: Synchroner Zyklus



Ungunstigster Fall: Das Signal  $\overline{VPA}$  kommt zu spät an, um die Setup-Zeit (47) einzuhalten. Es muß auf den nächsten E-Zyklus gewartet werden.

Abb. 2.27. Synchroner Zyklus

Die Kommunikation zwischen dem MC68000 und den Bausteinen der 6800-Familie ist dank der Signale E,  $\overline{VPA}$  und  $\overline{VMA}$  recht einfach. In Abb. 2.28 wird das Zusammenspiel verdeutlicht.



Abb. 2 28: Synchrone Kommunikation (MC68000 - 6800-Familie)

Wenn der Decodierbaustein ein Signal CS erzeugt und das Signal  $\overline{AS}$  anliegt, wird automatisch ein Signal  $\overline{VPA}$  erzeugt. Der 68000 wird nun davon unterrichtet, daß er mit einem im Synchron-Modus arbeitenden peripheren Baustein kommunizieren wird. Er sendet  $\overline{VMA}$ . Über die Verbindung von  $\overline{VMA}$  und CS wird der periphere Baustein adressiert, der anschließend den Datentransfer vornehmen kann.

Der Schaltplan in Abb. 2.29 zeigt den synchronen Anschluß eines Bau steins der 6800-Familie, dem 6821, an den MC68000

Einige Anwendungen benötigen aber einen anderen Takt als den E-Takt, z. B. wenn man den MC6854, einen Baustein für asynchrone Datenübertragungs-Steuerung, ADLC (Asynchronous Data Link Controller), ansprechen will, der Datenübertragungen mit hoher Geschwindigkeit durchführt. Diese Geschwindigkeit ist natürlich abhängig von dem verwendeten Taktgeber; in dem genannten Beispiel benötigt man einen Taktgeber mit einer Frequenz von mindestens 2 MHz.

Der synchrone Übertragungsmodus zwischen dem 6854 und dem 68000 würde den 6854 dazu zwingen, sich nach dem E-Takt zu richten. Dies wäre aber ein Widerspruch zur Funktion dieses Bausteins.



Abb. 2 29. Synchrone Verbindung zwischen dem MC68000 und 2 PIA 6821

Es muß also eine Möglichkeit geben, die 6800-Bausteine und den MC68000 im Asynchron-Modus zu verbinden.

Die Abb 2.30 stellt eine schematische Übersicht eines solchen Verbindungstyps dar.

Puffer sind dazu da, um zu schreibende oder zu lesende Dateneinheiten zwischenzuspeichern. Ihre Arbeitsweise wird durch die Steuerlogik bestimmt, die von den Signalen R/W und CS abhängig ist.



Abb. 2.30: Schematische Darstellung einer asynchronen Verbindungsschaltung

Eine Schaltung hat die Aufgabe, das Signal DTACK zu erzeugen, nachdem ein Peripheriebaustein ausgewählt wurde. Diese Schaltung ist von der Adreßbestätigung abhängig, die ihrerseits der Start für den Beginn des Buszyklus, der Decodierung und des Peripheriezeitgebers ist

Um dieses Prinzip besser zu verstehen, betrachten wir das Schema in Abb. 2.31 im einzelnen.

Zuerst werden die Flip-Flops U1A und U1B auf 0 zurückgesetzt ( $\overline{UDS}$  oder  $\overline{LDS}$  = H zieht  $\overline{DS}$  = H nach sich).

Dies setzt DTACK in den High-Zustand, was den Puffern einen Transparent-Modus auferlegt.

Der Puffer U2 ist hochohmig, da  $\overline{OE}$ =H ist. Der Puffer U3 ist durchgeschaltet, da  $\overline{OE}$ =L ist.

Wenn es sich um einen Schreibvorgang handelt, bleibt der Puffer U3 zu Beginn des Zugriffszyklus durchgeschaltet. Handelt es sich um einen Lesevorgang – R/W=H, CS=H, und der Ausgang von U4A ist low –



Abb. 2.31. Asynchrone Verbindung zwischen dem MC68000 und einem 6800-Peri pheriebaustein

wird U2 durchgeschaltet, und U3 wird in den hochohmigen Zustand versetzt. Um den Zugriff zum peripheren Baustein zu ermöglichen, ist es notwendig, daß  $U\overline{DS}$  oder  $\overline{LDS}$ -L sind und folglich DS=H und CS=H.

Auf diese Weise wird sich der Ausgang Q des Flip-Flops U1A an der ersten fallenden Flanke des Takts E im High-Zustand befinden, um den Peripheriebaustein zu aktivieren. An der zweiten fallenden Flanke von E geht der Ausgang  $\overline{Q}$  des Flip-Flops U1B in den Low-Zustand über. Das Signal  $\overline{DTACK}$  wird gesendet, und die Daten werden in dem entsprechenden Puffer gespeichert. Das Signal  $\overline{DTACK}$  wird in U4D invertiert, was das Peripheriegerät freigibt. Schließlich, wenn  $\overline{UDS}$  oder  $\overline{LDS}$  wieder auf High gesetzt werden und  $\overline{DS}=H$  ist, werden die Flip Flops U1A und U1B auf 0 zurückgesetzt und die Schaltungen auf den nächsten Zugriff vorbereitet.

Die Schaltplane in Abb. 2.32 und 2.33 stellen Anwendungen dieses Prinzips vor.



Abb 2.32 Verbindung zwischen dem MC68000, einem programmierbaren Zeitgeber (6840) und einem Baustein für asynchrone Datenübertragungs-Steuerung (6854) im Asynchron-Modus

# BUSZUWEISUNGSSTEUERUNG

Die Buszuweisungssteuerung ermöglicht einem externen Baustein, der fähig ist, die Bussteuerung zu übernehmen, eine Busanforderung zu stellen, danach eine Bestätigung zu erhalten und schließlich die Kontrolle selbst zu bekommen.

In der Praxis läuft das so ab:

Der externe Baustein stellt eine Busanforderung – BR (Bus Request).



Abb. 2.33: Verbindung zwischen dem MC68000 und zwei PIA (6821)

- Empfang der Anforderung und Bestätigung, daß der Bus am Ende des ablaufenden Zyklus frei wird – BG (Bus Grant).
- Der externe Baustein gibt an den Prozessor das Signal für die Busfreigabeerkennung zurück
   BGACK (Bus Grant ACKnowledge).

Dieser Steuerungstyp ermöglicht die Realisierung von Multiprozessor-Anwendungen: CPU, DMAC, MMU etc., bei denen jeder mögliche Verwalter die Kontrolle übernehmen kann.

Der Ablauf bei der Übergabe der Buskontrolle ist in Abb. 2.34 wiedergegeben.



Abb 2.34: Ablauf bei der Übergabe der Buskontrolle

# Erläuterung des Ablaufschemas (Abb. 2.34)

# Busanforderung

Ein externer Baustein, der in der Lage ist, die Verwaltung der Busse zu übernehmen, fordert die Buskontrolle durch Senden des Signals BR. Dadurch wird der Prozessor darauf hingewiesen, daß ein externer Baustein die Bussteuerung zu übernehmen wünscht. Der 68000 hat immer eine geringere Buspriorität als der anfragende Baustein, und er übergibt die Buskontrolle, sobald er den letzten angefangenen Buszyklus beendet hat.

Wenn er vor dem Zurücksetzen des Signals  $B\overline{R}$  keine Busfreigabeerkennung ( $\overline{BGACK}$ ) empfängt, fährt der Prozessor unbeirrt mit seiner Arbeit fort, bis  $\overline{BR}$  zurückgesetzt wird Dies ermöglicht die Fortsetzung der Verarbeitung in dem Fall, wo der anfragende Baustein vielleicht aus Unachtsamkeit einer anhangenden Schaltung geantwortet hat.

# Einverständnıs des Prozessors

Der Prozessor erkennt die Busanforderung so bald wie möglich an, indem er mit  $\overline{BG}$  bestätigt. Normalerweise findet das sofort nach der internen Synchronisierung von  $B\overline{G}$  statt. Die einzige Ausnahme dieser Regel ist, wenn der Prozessor, nachdem die interne Entscheidung, den nächsten



Abb. 2.35: Zeitdiagramm fur die Steuerung der Buskontrolle

Zyklus durchzuführen, getroffen ist, nicht weit genug im Zyklus fortgeschritten ist, um  $\overline{AS}$  zu senden. Die Bestätigung BG findet also immer einen Taktzyklus nach dem Senden von  $\overline{AS}$  statt.

Das Zeitdiagramm in Abb. 2.36 zeigt einen solchen Fall.



Abb. 2.36: Zeitdiagramm. Das Signal BG wird verzögert

# Busfreigabeerkennung

Wenn der anfragende Baustein  $\overline{BG}$  empfängt, wartet er zunächst darauf, daß

AS DTACK BGACK

zurückgesetzt worden sind, bevor er das Signal BGACK sendet.

- Das Zurücksetzen von AS deutet darauf hin, daß der vorhergegangene Bus-Master seinen Zyklus beendet hat.
- Das Zurücksetzen von DTACK bedeutet, daß die entsprechende untergeordnete Schaltung ihre Aufgabe beendet und die Verbindung unterbrochen hat. In einigen Anwendungen darf allerdings das Signal DTACK überhaupt nicht benutzt werden. Die universellen Schaltungen müssen also so verkoppelt sein, daß sie nur von AS abhängig sind.
- Das Zurücksetzen von BGACK gibt dem anfragenden Baustein an, daß der vorhergehende Bus-Master die Busse freigegeben hat. Wenn er das Signal BGACK gesendet hat, ist der Baustein Master, bis er selbst BGACK zurücksetzt, nachdem er seinen Zyklus vollständig beendet hat.

Beispiel der Buszuweisungssteuerung zwischen dem 68000 und dem DMAC 6844

Der DMA Controller DMAC (Direct Memory Access Controller) besitzt vier Übertragungskanäle. Mit jedem Kanal sind verbunden:

- ein Eingang TxRQ, der von einem peripheren Baustein gesetzt wird, der eine DMA-Verarbeitung wünscht;
- ein 16 Bit-Adreßregister, in dem die Startadresse des zu übertragenden Datenblocks gespeichert wird;
- ein 16-Bit-Zähler, der die Anzahl der zu übertragenden Bytes aufnimmt.

Dieser Baustein besitzt verschiedene Betriebsarten. Es genügt jedoch zu wissen, daß, wenn eine Übertragungsanforderung vorliegt (TxRQ=H), der DMAC das Ausgangssignal  $\overline{DRQH}$  sendet. Danach wartet er auf die Anerkennung der Anfrage, in dem Fall auf den Empfang des Signals DGRNT. In diesem Moment beginnt die Datenübertragung. Am Ende dieser Übertragung wird der Ausgang  $\overline{TxSTB}$  gesetzt und der Ausgang  $\overline{DRQH}$  zurückgesetzt.

Der Schaltplan dieser Verbindung ist in Abb. 2.37 zu sehen.



Abh 2.37 Schaltung für die Verbindung eines DMAC 6844 mit dem MC68000

# Erläuterung der Schaltung (Abb. 2.37)

Das System ist im Ruhezustand, also  $\overline{DRQH}=1$ , DGRNT=0 und  $\overline{TxSTB}=1$ . Der Eingang von U2, der von U6A kommt, ist demzufolge 1. Ein DMA-Gesuch erreicht den Controller: Über U1 wird der zweite Eingang von U2 auf 1 gesetzt, der Ausgang sendet 0. Das Signal BR wird gesendet. Der 68000 bestätigt mit  $\overline{BG}$  und gibt die Busse frei. Der DMAC antwortet, indem er durch Senden von DRQH bestätigt. Die anderen Signale haben folgende Werte:

BGACK-1 DTACK=1 AS=1 BG=0

Der Decodierbaustein U4 kann seinen Ausgang  $\overline{O3}$  setzen, was bewirkt, daß DGRNT gesendet wird (DGRNT=1) und  $\overline{BR}$  über U6A und U2 zurückgesetzt wird.

Der Baustein DMAC kann seine Datenübertragungen beginnen. Außerdem muß aber noch BGACK gesetzt werden. DRQH ist 0 und TxSTB ist 1, also ist der Ausgang U3D=1. Folglich ist DGRNT=1 und U3B=0.

BGACK kann somit gesendet werden. Der 68000 setzt kurz danach BG zurück.

Das Ende der Kontrolle durch den DMAC-Baustein läuft folgendermaßen ab: Wenn der Datentransfer beendet ist, wird der Ausgang  $\overline{T} \times S \overline{T} B$  auf 0 gesetzt. Die Flip-Flops U3A und U3B werden also wieder auf 0 zurückgesetzt, da  $\overline{D}RQH$  vom DMAC intern zurückgesetzt worden ist. Ist  $\overline{D}RQH$ =1, geht der Ausgang U3D auf 0, der Ausgang U3B auf 1, und  $\overline{B}\overline{G}ACK$  ist zurückgesetzt.

Ebenso ist  $\overline{O3} = 1$  und  $\overline{BGACK} = 1$ , dann ist DGRNT=0.

## Übungen

- 2.1: Wie lange dauert ein Lese- bzw. Schreibzyklus mindestens?
- 2.2: In welcher Reihenfolge werden die folgenden Signale oder Busse während eines Lese- und eines Schreibzyklus gesetzt?

Adreßbus

AS

**UDS** 

LDS

 $R/\overline{W}$ 

- 2.3: Welche besondere Eigenschaft zeichnet einen Lese /Anderungs-/ Schreibzyklus aus?
- 2.4: Welche Voraussetzungen sind für den Neustart eines Zyklus nötig?
- 2.5: Welche drei Voraussetzungen sind für die Bestätigung des Signals BGACK nötig. Erklären Sie sie.

## Lösungen

- 2.1: Die minimale Dauer eines Lese- bzw. Schreibzyklus beträgt vier Takte.
- 2.2: Bei einem Lesevorgang ist es folgendermaßen:
  - Setzen von R/W̄.
  - Ausgabe der Adresse auf A1-A23.
  - Bestätigung der Adreßgültigkeit AS.
  - Setzen von UDS oder/und LDS.

Bei einem Schreibvorgang läuft es so ab:

- Ausgabe der Adresse auf A1–A23.
- Bestätigung durch AS.
- Setzen von R/W̄.
- Setzen von UDS, LDS (nachdem die zu schreibenden Daten auf den Datenbus gelegt worden sind).
- 2.3: Während dieses Vorgangs bleibt das Signal AS die ganze Zeit gesetzt. Das verhindert den Eingriff einer externen Schaltung fur die Dauer eines Zyklus.
- 2.4: Um den Neustart eines Zyklus zu bewirken, müssen die Signale BERR und HALT gesendet werden.
- 2.5: Damit ein anfragender Baustein die Busfreigabeerkennung senden kann, mussen die Signale AS, DTACK und BGACK zurückgesetzt worden sein. D. h.:
  - Der Prozessor benötigt die Busse nicht mehr.
  - Kein anderer peripherer Baustein hat eine Anforderung gestellt
  - Kein anderer Prozessor hat die Buskontrolle.

Kapitel 3

## Die Ausnahmezustände

#### ALLGEMEINE BETRACHTUNGEN

Der MC68000 befindet sich immer in einem der folgenden Zustände:

- Normalzustand
- Ausnahmezustand
- Haltezustand
- Der Normalzustand entspricht der Ausführung von "normalen" Befehlen, d. h. Befehlen, die keine Unterbrechungs- oder Ausnahmeprozeduren erzeugen.

Ein Spezialfall des Normalzustandes ist derjenige, der durch den Befehl STOP erzeugt wird. Der Prozessor befindet sich im "gestoppten" Zustand.

Der Ausnahmezustand ist die Antwort des Prozessors auf Unterbrechungen, Ausführung des Befehls TRAP und anderer Abweichungen im Programmablauf.

Die Ausnahme wird intern durch einen Befehl oder eine außergewöhnliche Bedingung, die während der Ausführung eines Befehls eintritt, erzeugt. Extern wird sie durch einen Befehl, einen Bussehler oder RESET generiert.

 Der Haltezustand weist auf einen schwerwiegenden Hardware-Fehler hin.

Tritt beispielsweise während der Ausführung einer Busfehler-Ausnahmeprozedur ein zweiter Busfehler auf, so kommt der Prozessor zum Stillstand. Nur ein externes RESET kann den Wiederanlauf bewirken.

Achtung: Der Haltezustand ist nicht mit dem STOP-Zustand zu verwechseln.

Der Prozessor kann zwei verschiedene Betriebsmodi annehmen:

- den Anwendermodus und
- den Überwachungsmodus, auch privilegierter oder Supervisor-Modus genannt.

Die Existenz eines privilegierten Modus gibt dem System eine große Sicherheit: Die Anwenderprogramme können nicht auf Informationen zugreifen, die nicht verändert werden dürfen.

## Der Überwachungsmodus

- Der Zustand wird durch das Bit S des Statusregisters SR bestimmt (S=1).
- Alle Befehle stehen zur Verfügung.
- Der verwendete Stapelzeiger ist der Zeiger des Überwachungsstapels SSP (Supervisor Stack Pointer).

#### Der Anwendermodus

Der Zustand wird ebenfalls durch das Bit S des Statusregisters SR bestimmt (S=0).

 Die Befehlsskala ist beschränkt: Verboten sind beispielsweise die Befehle STOP und RESET sowie die Befehle, die das Statusregister und die Transfers zum oder vom Anwenderstapelzeiger verändern.

## Wechsel zwischen Anwender- und Überwachungsmodus

Wenn sich der Prozessor im Anwendermodus befindet, können nur Ausnahmeprozeduren einen Übergang in den Überwachungsmodus bewirken (Abb. 3.1).

Der Übergang vom Überwachungs in den Anwendermodus kann durch vier verschiedene Befehle erreicht werden:

- RTE (Rückkehr aus einem Ausnahmezustand)
- MOVE Wort ins SR (Transfer eines Wortes in das Statusregister)



Abb. 3.1: Ubergang vom Anwender- in den Überwachungsmodus

ANDI mit SR (logisches UND unmittelbar)
 EORI mit SR (Exklusives ODER unmittelbar)

Der nächste Befehl wird folglich in dem Zustand ausgeführt, der durch den neuen Wert von S festgelegt worden ist (Abb. 3.2).



Abb. 3.2: Zustandswechsel

#### DIE AUSNAHMEVEKTOREN

Ausnahmevektoren sind Informationen, die sich im Speicher befinden und die dem Prozessor die Möglichkeit geben, die Ausnahmeprozeduren in Gang zu bringen. Alle Ausnahmevektoren sind zwei Worte lang (32 Bit), ausgenommen der Vektor RESET, der sich auf vier Worte erstreckt.

Die Vektoren befinden sich im Speicherbereich "Supervisor-Daten", außer dem RESET-Vektor, der zu den "Supervisor-Programmen" zählt

Die Vektornummer gibt die Adresse eines Vektors an. Diese Nummer wird intern oder extern gemäß der Ausnahme erzeugt. Beispielsweise wird die Vektornummer der Ausnahme  $\overline{BERR}$  intern berechnet, und zwar ist sie 2. Die Nummer einer Unterbrechung, die vom Baustein DMAC erzeugt wird, ist hingegen von dem externen Gerät geliefert worden. Bei Unterbrechungen liefert der periphere Baustein wahrend der Anerkennungsphäse der Unterbrechung dem Prozessor eine 8-Bit-Vektornummer über die Leitungen D0. D7.

Der Prozessor wandelt die 8-Bit-Zahl in eine 24-Bit-Adresse um, indem er sie mit 4 multipliziert.

#### Aufbau der Vektornummer:

| D15 |   |   |   |   |   |   |   | D7 |    |    |    |    |    |    | D0 |
|-----|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|
| Х   | х | Х | Х | х | х | Х | Х | V7 | V6 | V5 | V4 | V3 | V2 | V1 | VO |

## Aufbau der umgerechneten Adresse:

| A23 |   |   | <b>A</b> 9 |    |   |    |    |    |    |    |   | <b>A</b> 0 |  |
|-----|---|---|------------|----|---|----|----|----|----|----|---|------------|--|
| 0   | 0 | 0 | V7         | V6 | Ĭ | V4 | V3 | V2 | V1 | V0 | 0 | 0          |  |

Die Vektoren werden in einer Tabelle verwaltet, wie in Abb. 3.3 zu sehen ist.

| Nummer               | Adre | sse | Betroffene Ausnahme                        |  |  |
|----------------------|------|-----|--------------------------------------------|--|--|
| des Vektors Dez. Hex |      | Нөх |                                            |  |  |
| 0                    | 0    | 000 | Reset: Initialisierung von SSP             |  |  |
| _                    | 4    | 004 | Reset: Initialisierung von PC              |  |  |
| 2                    | 8    | 800 | Busfehler                                  |  |  |
| 3                    | 12   | 00C | Adreßfehler                                |  |  |
| 4                    | 16   | 010 | lllegaler Befehl                           |  |  |
| 5                    | 20   | 014 | Division durch Null                        |  |  |
| 6                    | 24   | 018 | Befehl CHK                                 |  |  |
| 7                    | 28   | 01C | Befehl TRAPV                               |  |  |
| 8                    | 32   | 020 | Privilegverletzung                         |  |  |
| 9                    | 36   | 024 | Abiaufverfolgung                           |  |  |
| 10                   | 40   | 028 | Befehl mit 1010 am Anfang                  |  |  |
| 11                   | 44   | 02C | Befehl mit 1111 am Anfang                  |  |  |
| 12                   | 48   | 030 | Reserviert                                 |  |  |
| 13                   | 52   | 034 | Reserviert                                 |  |  |
| 14                   | 56   | 038 | Aeserviert                                 |  |  |
| 15                   | 60   | 03C | Nicht initialisierter Unterbrechungsvektor |  |  |
| 16-23                | 64   | 040 | Reserviert                                 |  |  |
|                      | 95   | 05F |                                            |  |  |
| 24                   | 96   | 060 | Unechte Unterbrechung                      |  |  |
| 25                   | 100  | 064 | autovektorielle Unterbrechung, Ebene 1     |  |  |
| 26                   | 104  | 068 | autovektorielle Unterbrechung, Ebene 2     |  |  |
| 27                   | 108  | 06C | autovektorielle Unterbrechung, Ebene 3     |  |  |
| 28                   | 112  | 070 | autovektorielle Unterbrechung, Ebene 4     |  |  |
| 29                   | 116  | 074 | autovektorielle Unterbrechung, Ebene 5     |  |  |
| 30                   | 120  | 078 | autovektor elle Unterbrechung, Ebene 6     |  |  |
| 31                   | 124  | 07C | autovektorielle Unterbrechung, Ebene 7     |  |  |
| 32-47                | 128  | 080 | TRAP-Befehlsvektoren                       |  |  |
|                      | 191  | 0BF | _                                          |  |  |
| 48 63                | 192  | 0C0 | Reserviert                                 |  |  |
|                      | 255  | OFF | _                                          |  |  |
| 64-255               | 256  | 100 | Anwender-Unterbrechungsvektoren            |  |  |
|                      | 1023 | 3FF | ****                                       |  |  |

Abb. 3.3: Tabelle der Ausnahmevektoren

Nachdem wir nun das Prinzip der Ausnahmevektoren erklärt haben, wollen wir im folgenden Abschnitt anhand eines Ablaufschemas die Abarbeitung einer Ausnahme kommentieren (Abb. 3.4).



Abh. 3.4: Ablaufschema der Verarbeitung einer Ausnahme

## VERARBEITUNG EINER AUSNAHME

#### Erster Schritt

Der Inhalt des Statusregisters wird als Kopie in einem internen Register abgelegt. Dann wird das Bit S gesetzt, also der Prozessor in den Uberwa chungsstatus versetzt. Das Bit T wird auf 0 gesetzt Dies ermoglicht der Ausnahmeprozedur, ohne Behinderung durch den Trace-Modus (Trace ist eine Ausnahme) abzulaufen.

Entsprechend der jeweiligen Unterbrechung und des Reset, wird die Unterbrechungsmaske mit der entsprechenden Prioritätsebene versehen (Ebene 7 für RESET).

#### Zweiter Schritt

Die Vektornummer der Ausnahme wird bestimmt.

- Bei Unterbrechungen wird dem Prozessor die Nummer während der Anerkennungsphase der Unterbrechung geliefert.
- Bei den anderen Ausnahmen, den autovektoriellen Unterbrechungen, bestimmt die interne Logik des Prozessors die Vektornummer.

#### Dritter Schritt

Der derzeitige Zustand des Prozessors wird außer beim Reset gerettet.

Der aktuelle Wert des Programmzählers PC und die gesicherte Kopie des Statusregisters SR werden in den Überwachungsstapel geschrieben. Der Inhalt des Programmzählers ist im allgemeinen die Adresse des nächsten Befehls, der ausgeführt worden wäre, wenn keine Ausnahme eingetreten wäre. Dennoch ist der in den Stapel gesetzte Wert des PC im Falle eines Bus- oder Adreßfehlers unvorhersehbar (aufgrund des Vorgriffphänomens) und kann um einen bestimmten Betrag höher sein als die Adresse des Befehls, der den Fehler verursacht hat. Auf jeden Fall werden bei Bus- und Adreßfehlern zusätzliche Informationen, die den aktuellen Zustand dokumentieren, in den Stapel geschrieben.

## Vierter Schritt

Der Inhalt des Ausnahmevektors wird in den Programmzähler geladen. Der Prozessor nimmt nun die Ausfuhrung der durch den PC adressierten Befehle wieder auf. Bevor wir die Ausnahmen gemäß der Tabelle in Abb. 3.5 klassifizieren, ernnern wir uns daran, daß die Prioritätsfrage entschieden wird, wenn zwei Ausnahmen gleichzeitig auftreten, um zu bestimmen, welche zuerst bearbeitet werden muß.

| Priontät<br>der<br>Gruppen | Gruppen | Ausnahme                                                                        | Pnorität<br>im Inneren<br>einer Gruppe                              | Augenblick, in dem<br>die Ausnahrne<br>anerkannt wird                                                      | Augenblick, in dem<br>die Verarbeitung<br>der Ausnahme be<br>ginnt (dieser kann<br>gegebenenfalls<br>durch HALT, BR<br>verzögent werden) |
|----------------------------|---------|---------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>†</b>                   | 0       | RESET<br>Busiehler<br>Adressfehler                                              | <b>†</b>                                                            | Ende des Taktzyklus<br>Der laufende Befehi<br>wird abgebrochen                                             | Nachster Taktzyklus                                                                                                                      |
|                            | 1       | TRACE Jnterbrechung 1 legaler Bet Bef nicht implementiert privilegierter Befehl | 1                                                                   | Ende der Ausführung<br>des laufendenen<br>Befehls<br>Ende des Buszyklus<br>Laufender Befehl<br>abgebrochen | Nach dem aufenden<br>Belehl und vor dem<br>nächsten Belehl                                                                               |
|                            | 2       | TRAP<br>TRAPV<br>CHK<br>Division<br>durch Null                                  | Keine Priorität,<br>da jeder Befehl<br>separat ausge-<br>führt wird | arbeitung des                                                                                              | Nach dem Ende<br>des laufenden<br>Befehlszyklus                                                                                          |

Abb. 3.5: Die verschiedenen Gruppen von Ausnahmezuständen

## Wir betrachten zwei Beispiele:

- Ein Bussehler tritt während eines TRAP-Besehls auf: Der Bussehler wird vorrangig behandelt, und die Ausführung des TRAP-Besehls wird abgebrochen.
- Eine Unterbrechungsanforderung trifft während der Ausführung eines Befehls ein, und T ist gesetzt: TRACE ist vorrangig und wird zuerst, vor der Unterbrechung, berücksichtigt. Die Unterbrechung kommt dann zum Zuge, bevor die weiteren Befchle abgearbeitet werden.

Der detaillierte Ablaufplan zur Behandlung von Ausnahmen (Abb. 3.6) zeigt alle Schritte auf, die der Prozessor durchlaufen muß, bevor er weiß, welche Ausnahmeprozedur er ausführen muß.



Abb 3.6. Detaillierter Ablaufplan für die Verarbeitung von Ausnahmen (außer RESET)

## BEARBEITUNG DER UNTERSCHIEDLICHEN AUSNAHMETYPEN

Die verschiedenen Ausnahmen, die in diesem Kapitel behandelt werden sollen, sind die folgenden:

- 1. Unterbrechungen
- 2. RESET
- 3. Befehle des Typs TRAP
- 4. Illegaler oder nicht implementierter Befehl
- 5. Privilegverletzung
- 6. TRACE
- 7. Busfehler
- 8. Adreßfehler
- 9. Unechte Unterbrechung

#### UNTERBRECHUNGEN

Unterbrechungsanforderungen werden über die Unterbrechungs-Steuerleitungen IPLO, IPLI und IPL2 geschickt, die 7 Prioritätsebenen zur Verfugung stellen.

Die externen Bausteine können mit Hilfe eines Prioritätscodierers verkettet werden, damit einer großen Anzahl von Schaltungen ermöglicht werden kann, den Prozessor zu unterbrechen (Abb. 3.7).

Die Unterbrechungsanforderung wird also durch die codierte Unterbre chungsebene auf den Leitungen IPLO-IPL2 realisiert.

Achtung: IPL0, IPL1 und IPL2 sind low-aktiv, während das bei I0, I1 und I2 des Statusregisters genau umgekehrt ist.

Es gibt 7 Prioritätsebenen:

Die Ebene 7 hat die höchste Priorität, ist nicht maskierbar und für die Systeminitialisierung und den Wiederanlauf bestimmt. Das bedeutet auch, daß jede Unterbrechung der Ebene 7 von einer Unterbrechung der Ebene 7 unterbrochen werden kann.

Ebene 0 bedeutet, daß niemand eine Unterbrechungsanforderung gestellt hat.

Die Ebenen 1 bis 6 sind maskierbar (Abb. 3.8). Wenn eine Unterbrechung erkannt wird, wird ihre Prioritätsebene mit der Unterbrechungsmaske im Statusregister verglichen. Ist die Priorität gleich oder kleiner als



Abb 37: Verkettung von Unterbrechungen

die der Maske, wird die Unterbrechung verhindert. Auf diese Weise wird also die Verarbeitung mit dem nachfolgenden Befehl fortgesetzt. Der Unterbrechungsanforderung wird nicht stattgegeben. Sie könnte ausgeführt werden, wenn der Wert der Maske im folgenden niedriger als der der Unterbrechungsebene ist und die Anforderung immer noch vorliegt. Die Unterbrechungsanforderungen, die an den Prozessor gesendet werden, verlangen also keine sofortige Bearbeitung. Vor der Übernahme wird die Unterbrechung als "schwebend" bezeichnet (pending interrupt).

Wenn die Priorität der wartenden Unterbrechung höher als die der momentan ablaufenden ist, ist die Verarbeitungssequenz die folgende:

- Kopie des Statusregisters.
- Setzen von S auf 1.
- Setzen von T auf 0.
- Die Maske des Statusregisters wird auf die Ebene der übernommenen Unterbrechung gesetzt.

Der Prozessor ermittelt die Vektornummer, geht in die Phase der Unterbrechungsanerkennung über und gibt die Prioritätsebene der Unterbrechung auf die Adreßleitungen A1, A2 und A3 aus. Zwei Fälle können auftreten:

## Erzengen einer Autovektornummer

Ein externer Baustein sendet das Signal VPA, was den Prozessor veranlaßt, eine Autovektornummer zu erzeugen. Er erzeugt intern und unabhängig von der Prioritätsebene der Unterbrechung eine Vektornummer.



Abb. 3.8: Beziehung zwischen den Unterbrechungsmasken und den Unterbrechungseingängen

## Die nicht-autovektorielle Unterbrechung

Eine externe Logik liefert die Nummer des Vektors, legt sie auf den Datenbus und beendet die Übertragung, indem sie DTACK bestätigt.

Im zweiten Fall, wo die externe Logik einen Busfehler meldet, wird der Prozessor die Vektornummer erzeugen.

- Danach werden PC und SR auf den Überwacherstapel gerettet.
- Schließlich wird der Programmzähler mit dem Inhalt der berechneten Vektoradresse geladen und die entsprechende Programmroutine ausgeführt.

Im Ablaufdiagramm der Abb. 3.9 wird der Verarbeitungsprozeß einer Unterbrechung zusammengefaßt.



Abh. 3.9: Ablaufdiagramm für das Auftreten einer Unterbrechung



Abb. 3 10: Schemadiagramm für das Auftreten einen nicht-autovektoriellen Unterbrechung

## Der Fall der nicht-automatischen Vektorisierung

Dieser Unterbrechungstyp wird durch einen Dialog zwischen dem Baustein als Verursacher der Unterbrechung und dem Prozessor charakterisiert, wie es das Ablaufdiagramm der Abb. 3.10 und das Zeitdiagramm der Abb. 3.11 zeigen.



Abb. 3.11: Zeitdiagramm für das Auftreten einer nicht-autovektoriellen Unterbrechung

## Die Verarbeitung der 192 Anwender-Unterbrechungen

Für den Fall der Anwender-Unterbrechungen stehen 192 Unterbrechungsvektoren zur Verfügung.

Auf diese Weise kann für jede Zahl unter 193 eine Vektornummer zugeordnet werden, die gleichzeitig die Priorität festlegen kann.

Die Vektoren sind von 64 bis 255 durchnumeriert. Die 192 Prioritätsebenen können in 8 Bits codiert werden, z. B. die Vektornummer 64 mit der niedrigsten (00000000) und die Vektornummer 255 mit der höchsten Priorität (10111111). Von dieser Prioritätsschreibweise ausgehend kann man die Vektornummmer durch Addition der Zahl 64 zur jeweiligen Prioritätsnummer erreichen.

In dem Blockdiagramm mit der Generierungsschaltung für Vektornumern, Abb. 3.12, werden zwei Speicherelemente L1 und L2 verwendet.



Abb. 3.12. Generierungsschaltung für Vektornummern

- L1 unterbindet jede weitere Unterbrechung, bevor nicht L2 die aktuelle Vektornummer gespeichert hat.
- L2 entnimmt dem Datenbus die Vektornummer und speichert sie, bis die Unterbrechungsquittung TACK erfolgt ist, die besagt, daß der 68000 die Unterbrechung anerkannt hat.

Nach einer genügend langen Zeit, die für die Speicherung der Vektornummer ausreicht, läßt L1 wieder neue Unterbrechungen zu.

## Die autovektorielle Unterbrechung

Der Ablauf der autovektoriellen Unterbrechung ist in dem Ablaufdiagramm der Abb. 3.13 und dem Zeitdiagramm in Abb. 3.14 dargestellt.



Abb. 3.13. Ablaufdiagramm für das Auftreten einer autovektoriellen Unterbrechung



Abb 3.14: Zeitdiagramm für das Auftreten einer autovektoriellen Unterbrechung

Das vereinfachte Schema in Abb. 3.15 zeigt die Schaltung für eine autovektorielle Unterbrechung zwischen dem PIA 6821 und dem 68000.

- Der MC68000 erhalt eine Unterbrechungsanforderung TRQA oder TRQB über die Unterbrechungssteuerleitungen TPL0, TPL1 und TPL2.
- 2. Der MC68000 adressiert den 6821 und setzt sich selbst auf Erkennung der Unterbrechung: AS=0, FC0=FC1=FC2=1
- 3. Der Prozessor empfängt VPA.
- 4. Er erzeugt intern die Vektornummer.

Eine Erweiterung des Prinzips stellt das Schaltschema in Abb. 3.16 dar. Mehrere PIAs (6821) und ein ACIA (6850) unterbrechen den 68000.



Abb 3 15: Vereinfachtes Schaltschema für eine autovektorielle Unterbrechung des MC68000 mit dem PIA 6821

Schließlich verbinden wir die zwei Unterbrechungsarten in dem Schema der Ahb. 3.17 miteinander.

## **RÜCKSETZUNG (RESET)**

Der Anschluß RESET ist bidirektional.

## Als Eingang:

Beim Einschalten des Stroms wird eine generelle Rücksetzung des Systems (Prozessor und externe Schaltungen) erzielt, indem während 100 ms RESET und HALT am 68000 angelegt werden.

Der Prozessor liest dann ab Adresse \$000000 in der Vektortabelle die entsprechende Vektornummer nach Der Inhalt dieser Adresse wird in den Überwacherstapel geladen Dieser ist nun initialisiert.

Danach liest der Mikroprozessor automatisch den Inhalt der Adresse \$000004 und legt ihn im Programmzähler PC ab. Der Prozessor kennt nun die Adresse des ersten auszuführenden Befehls



Abb 3 16: Mehrere PIAs und ein ACIA können den MC68000 autovektoriell unterbrechen



Abb. 3.17. Schaltplan für vektorielle und autovektorielle Unterbrechung

Schließlich setzt er die Unterbrechungsmaske des Statusregisters auf die höchste Ebene (Level 7).

RESET ist für den Wiederanlauf des Systems nach schwerwiegenden Fehlern bestimmt. Während eines RESET wird jede laufende Verarbei-



Abb. 3.18: Ablauf einer Rücksetzung (RESET)

tung vorzeitig abgebrochen und kann auch später nicht fortgeführt werden. Der Prozessor fallt in den Überwachungsmodus, und der TRACE-Modus wird ausgeschaltet.

Die Vektornummer 0 wird intern erzeugt.

Da keine Angaben über Inhalt der Register, insbesondere über den Zeiger des Überwacherstapels und den Programmzähler gemacht werden können, wird auch keine Hilfsroutine gestartet.

Tritt während der Initialisierungsphase ein Bus- oder Adreßfehler auf, kommt der Prozessor zum Stillstand, und die gesamte Verarbeitung hört auf. Nur ein erneutes RESET kann das System wieder starten

Diese RESET-Sequenz wird im Ablaufdiagramm der Abb. 3 18 dargestellt

## Als Ausgang:

Die Ausfuhrung des Befehls RESET bewirkt das Setzen des RESET-Signals für 124 Taktimpulse. Bei diesem Vorgehen wird das System durch den Prozessor selbst initialisiert.

Auf diese Weise wird keine Wirkung auf den Zustand des Prozessors ausgeübt; die Register bleiben unverändert. Nach beendeter Ausführung dieses Befehls wird der nachste Befehl bearbeitet.

#### BEFEHLE DES TYPS TRAP

Befchle des Typs TRAP können Ausnahmezustände veranlassen. Sie treten entweder bei Erkennen eines abnormalen Programmablaufs auf oder nach Ausführen von Befehlen, die die Aufgabe haben, einen Ausnahme zustand zu erzeugen.

#### Der TRAP-Befehl

Dieser Befehl erzwingt immer eine Ausnahme. 16 Vektoren sind für den TRAP-Befehl reserviert. Die Vektornummer wird intern erzeugt und stimmt mit dem Anfang der Tabelle überein, die die 16 verfugbaren Vektoren beinhaltet. Die genaue Nummer wird im Befehl (TRAP 0 bis TRAP 15) angegeben. Die Ausnahmeverarbeitung ist die gleiche wie bei Unterbrechungen. TRAP wird hauptsächlich für den Aufruf des Betriebssystems vom Anwenderprogramm aus verwendet. Das Prinzip wird in Abb. 3.19 veranschaulicht.



Abb. 3.19. Prinzipielle Arbeitsweise des TRAP-Befehls



Abb. 3.20: Prinzipielle Arbeitsweise des TRAPV-Befehls



Abb. 3.21 Prinzipielle Arbeitsweise des CHK-Befehls

#### Der TRAPV-Befehl

Der TRAPV-Befehl löst eine Ausnahmeverarbeitung nach dem TRAPV-Vektor aus, wenn die Voraussetzung für die Kapazitätsüberschreitung (overflow) eines Operanden erfüllt ist. Das Verarbeitungsschema sehen Sie in Abb. 3.20.

#### Der CHK-Befehl

Der CHK-Befehl überprüft, ob sich das untere Wort eines spezifizierten Datenregisters in dem Intervall 0 bis obere Grenze befindet.

Ist der Registerinhalt kleiner als 0 oder höher als die obere Grenze, wird eine Ausnahmeverarbeitung eingeleitet.

#### Der DIVS- und DIVU-Befehl

Die Befehle DIVS (dividiere mit Vorzeichen) und DIVU (dividiere ohne Vorzeichen) erzwingen eine Ausnahme, wenn eine Division durch Null beabsichtigt wird.

## ILLEGALE UND NICHTIMPLEMENTIERTE BEFEHLE

## Illegaler Befehl

Der Ausdruck illegaler Befehl bezeichnet ein Binärmuster, dessen Operationsteil nicht einer legalen Bitkombination für ein Befehlswort entspricht. Wenn ein solcher Befehl zur Ausführung gelangen soll, wird die Ausnahmebedingung "illegaler Befehl" signalisiert.

## Nichtimplementierter Befehl

Motorola hat nur ungefähr 80% der möglichen Bitkombinationen für die Implementierung von Befehlswörtern verwendet. Zu den unbenutzten Binärcodes gehören die Binärmuster 1010 und 1111 an den Stellen 12 bis 15, also die vier höchstwertigen Bits, die den Operationscode für einen Befehl darstellen.

Auf diese Weise kann die Verwendung nichtimplementierter Befehle softwaremäßig entdeckt werden, oder sie können bewußt für Emulationszwecke eingesetzt werden.

Die Verarbeitung von Ausnahmen entspricht der von Unterbrechungen, bei denen die Vektornummer intern erzeugt wird. Für die nichtimplementierten Operationscodes 1010 und 1111 wird die Vektornummer 10 bzw. 11 verwendet und für die illegalen Befehle die Vektornummer 4

## NICHTAUTORISIERTE VERWENDUNG PRIVILEGIERTER BEFEHLE

Um die Sicherheit eines DV-Systems zu garantieren, sind einige Befehle privilegiert. Sie können nur im Supervisor-Modus verwendet werden, und jeder Versuch, sie im Anwender-Modus zu benutzen, führt zu dem Ausnahmezustand "Privilegverletzung". Die privilegierten Befehle sind:

STOP RESET RTE MOVE to SR ANDI to SR EORI to SR ORI to SR MOVE USP

Die Vektornummer, die bei einem Ausnahmezustand des Typs Privilegverletzung erzeugt wird, ist 8.

## DIE BETRIEBSART TRACE

Diese Art der Befehlsausführung erlaubt eine Unterstützung der Programmentwicklung und Fehlerbehebung, indem die Befehle Schritt für Schritt ausgeführt werden. Nach jedem Befehl wird ein Ausnahmezustand veranlaßt, wenn vor der Ausführung des Befehls festgestellt wird, daß das T-Bit des Statusregisters gesetzt ist.

Im folgenden werden verschiedene Fälle betrachtet, in denen Ausnahmezustände eintreten, während der TRACE-Modus aktiviert ist.

## 1. Fall:

Der betreffende Befehl wurde nicht ausgeführt oder ist aus einem der folgenden Gründe abgebrochen worden:

- Eine Unterbrechungsanforderung ist erkannt worden
- Der Befehl ist ungültig oder privilegiert.

- RESET
- Busfehler
- Adreßfehler

Unter diesen Umständen kommt TRACE nicht zur Ausführung.

#### 2. Fall:

Der Befehl ist gerade in der Ausführung begriffen, und eine Ausnahme wird durch den Befehl herbeigeführt. Dann wird zuerst die Ausnahme abgearbeitet und danach der TRACE-Befehl.



Abb. 3.22: Aufeinanderfolge von mehreren Ausnahmen

Im Beispiel der Abb. 3.22 wird zunächst der TRACE-Modus aktiviert, und dann wird ein TRAP-Befehl ausgeführt, währenddessen eine Unterbrechung auftritt.

#### BUSFEHLER

Der Busfehler ist ein extern erzeugtes Eingangssignal, das einen beim Datentransfer aufgetretenen Fehler anzeigt, der über eine Ausnahme-prozedur abgefangen werden soll.

Beim Empfang von BERR wird der gerade ablaufende Buszyklus abgebrochen. Ein in der Ausfuhrung begriffener Befehl wird unterbrochen, um die Ausnahmesequenz einzuleiten, deren Ablauf teilweise schon bekannt ist:

- Kopie von SR
- -S=1
- Interne Generierung der Vektornummer

 Da der Prozessor den laufenden Befehl nicht beenden konnte, ist die Rettungsroutine komplexer und wird daher im einzelnen angegeben:

Speichern von PC, SR. Der gerettete Wert von PC wird um 2 bis 10 Bytes, ausgehend von der Adresse des ersten Wortes des Befehls, bei dem der Busfehler hervorgerufen wurde, erhöht (Vorgriffphänomen).

- Sicherung des Befehlsregisters.

- Sicherung der Adresse, für die die Anomalie aufgetreten ist

Speichern des Zustands von R/W, um festzuhalten, ob sich der Prozessor in einem Lese- oder Schreibvorgang befunden hat.
 Speichern des Zustands I/N, um anzugeben, ob der Prozessor gerade im Begriff war, einen Befehl auszuführen.

D. h.:

- I/N=0, normaler Befehl oder Ausnahme der Gruppe 2 (siehe Tabelle 3.23).
- I/N=1, der Prozessor verarbeitete eine Ausnahme der Gruppe 0 oder 1 (siehe Abb. 3.23).
- Speichern der Funktionscodes FC0, FC1 und FC2.

Mit Hilfe dieser Informationen ist es möglich, bei Auftreten eines Fehlers eine Software-Diagnose zu stellen. Tritt während der Verarbeitung einer Ausnahme ein weiterer Fehler auf, gibt es einen Doppelfehler, und der Prozessor kommt zum Stillstand. Dann kann nur RESET ihn neu starten.

| Gruppe | Ausnahme                                                                                     | Ausnahmeverarbeitung beginnt:                       |
|--------|----------------------------------------------------------------------------------------------|-----------------------------------------------------|
| 0      | Rucksetzung<br>Busfehler<br>Illegaler Adresse                                                | Am Ende eines Taktzyklus                            |
| 1      | TRACE, Unterbrechung<br>lliegaler Befehl.<br>Nichtvorhandener Befehl,<br>Privilegverletzung. | Am Ende eines Befehlszyklus Am Ende eines Buszyklus |
| 2      | TRAP, TRAPV,<br>CHK,<br>Division durch 0                                                     | Am Ende eines Befehlszyklus                         |

Abb. 3.23: Ausnahmegruppierung und Priorität

#### ADRESSFEHLER

Die Adreßfehler treten auf, wenn der Prozessor versucht, über eine ungerade Adresse einen Wort- oder Doppelwortoperanden anzusprechen.

Unter diesen Umständen wird der Buszyklus abgebrochen, und eine Ausnahmeverarbeitung wird durchgeführt, die der bei einem Busfehler ahnelt.

Abb. 3.24 zeigt eine Übersicht über Sicherungsvorgange bei Auftreten eines Bus- oder Adreßfehlers.



Abb 3 24: Sicherungsvorgänge im Fall eines Bus- oder Adressehlers

## DIE NICHTINITIALISIERTE UNTERBRECHUNG

Im Fall der Unterbrechung durch ein nichtinitialisiertes Peripheriegerät wird die Vektornummer 15 angenommen. So erzwingt beispielsweise ein RESET der Peripherie-Bausteine der 68000-Familie die Vektornummer 15. Auf diese Weise wird die mangelnde Fähigkeit dieser Peripherie-Bausteine ausgeglichen.

## Kapitel 4

# Die Speicherverwaltung

## DATENORGANISATION IM SPEICHER UND DIE BEDINGUNGSCODES

Zunächst wollen wir uns einmal die Organisation der Daten im Speicher vor Augen führen, damit wir die Begriffe "gerade" und "ungerade" Adressierung verstehen können. Der Speicher kann in 16-Bit-Einheiten dargestellt werden.

| Wort        | 000000      |
|-------------|-------------|
| Byte 000000 | Byte 000001 |
| Wort        | 000002      |
| Byte 000002 | Byte 000003 |
|             |             |
| Worl        | FFFFFE      |
| Byte FFFFE  | Byte FFFFFF |

Die Begriffe Byte, Wort und Doppel- oder Langwort werden im folgenden Schema näher veranschaulicht:



Jetzt können wir folgende Präzisierung vornehmen: Eine Byte-Adresse kann gerade oder ungerade sein, eine Wort Adresse muß gerade sein, und eine Doppelwort-Adresse muß auch gerade sein. Ein aus Worten zusammengesetzter Befehl muß darum notgedrungen auch eine gerade Adresse haben.

Beispiel für eine ungültige Adresse:

MOVE.W D1,\$3115 (Übertrage die 16 Bit von D1 zur Speicheradresse \$3115)

Diese Operation überträgt ein Wort. Daher ist die angegebene ungerade Adresse \$3115 unkorrekt.

In einem Befehl, der ein Datenregister Dn betrifft, gibt man dem Prozessor einen Datenlängencode an, um die bei dem Befehl verwendeten Datenlängen zu spezifizieren. Dabei bedeuten "B" (Byte), "W" (Wort) oder "L" (Langwort), daß sich die Operation auf 8 oder 16 Bit des niederwertigen Teils des Registers oder auf die ganzen 32 Bit des Registers bezieht.



Eine Verwendung dieser drei Varianten ist nicht bei allen Befehlen möglich. Insbesondere kann man für Operationen, die sich auf Adreßregister An beziehen, nicht ".B" verwenden.

## Beispiel:

MOVE.B An,\$2000 ist verboten!

Nur die Operationen unter Verwendung von ". W" und ". L" sind erlaubt

Beispiel: An ist der Quelloperand (Ursprungsdatenwort)

MOVE.W A1,\$2000 (Übertrage das Wort von A1 zur Adresse \$2000)



| E E \$2000 | E E \$2001

Beispiel: Wenn An der Zieloperand (Senke oder Bestimmungsoperand) ist und in der Operation "W" spezifiziert wird, wird der Operand vor Ausführung des Befehls vorzeichenbehaftet erweitert.

## Beispiel:

MOVE.W \$4000,A1 (Übertrage das Wort ab der Adresse \$4000 in das Register A1)

#### Wenn:



dann:

Ein weiteres Beispiel:

00001000 ORG \$1000 : Initialisierung des : Programms ab \$1000 00001000 327CB000 MOVE.W #\$8000, A1 : Übertragung von : \$8000 nach A1

**END** 

TOTAL ERRORS 0
TOTAL WARNINGS 0

D0 D7 26534354 30303033 46495820 00000000 20202020 20202020 00000000 100000061A0-A7 45533420 FFFF8000 00000000 30303033 000012BD 014E19F4 000000000 00000000 PC = 00001004 SR = 8000

## DAS BEDINGUNGSCODEREGISTER CCR

Das Bedingungscoderegister ist im unteren Teil des Statusregisters SR enthalten (Abb. 4.1).



Abb 4.1: Das Bedingungscoderegister ist ein Teil des Statusregisters

Wir wollen nun einige Beispiele von Operationen betrachten, die den Inhalt des Registers CCR verändern.

## Beispiel 1:

ADD.W D0,D1 (Addiere die Worte, die in D0 und D1 enthalten sind, und schreibe das Ergebnis in D1)

#### Vor der Ausführung:

#### Ausführung:

 $8013 \\ +8065 \\ \hline 10078$ 

# Nach der Ausführung:

Der Befehl ADD setzt die Bedingungscodes gemäß dem Resultat der Operation.

### Beispiel 2:

### Programm:

|          | 00001000     | ORG    | \$1000          |
|----------|--------------|--------|-----------------|
| 00001000 | 203C00218013 | MOVE.L | #\$00218013, D0 |
| 00001006 | 223C00038065 | MOVE.L | #\$00038065, D1 |
| 0000100C | 023C00E0     | ANDI   | #\$E0, CCR      |
| 00001010 | D240         | ADD.W  | D0, D1          |
|          |              | END    |                 |
| TOTAL F  | RRORS 0      |        |                 |

TOTAL ERRORS 0 TOTAL WARNINGS 0

Dieses Programm hat die Aufgabe, den 32-Bit-Wert \$00218013 in das Register D0 und den 32-Bit-Wert \$00038065 in das Register D1 zu laden. Dann werden die signifikanten Bits des Registers CCR auf 0 gesetzt, bevor die Addition von D0 und D1 in 16 Bits ausgeführt wird.

# Programmlauf:

|           |               |                        | MOVE.L   | #\$00218013, D0 |  |  |
|-----------|---------------|------------------------|----------|-----------------|--|--|
| D0-D7     | 00218013      | 30303033               | 46495820 | 00000000        |  |  |
|           | 20202020      | 20202020               | 00000000 | 00000061        |  |  |
| A0-A7     | 45533520      | 434E3130               | 00000000 | 30303033        |  |  |
|           | 000012BD      | 0162B1F1               | 00000000 | 00000000        |  |  |
| PC = 0000 | 01006  SR = - | MOVE.L #\$00038065, D1 |          |                 |  |  |
|           |               |                        |          |                 |  |  |
| D0-D7     | 00218013      | 00038065               | 46495820 | 00000000        |  |  |
|           | 20202020      | 20202020               | 00000000 | 00000061        |  |  |

|            |               | 10.150.00 | 00000000 | 20202022       |
|------------|---------------|-----------|----------|----------------|
| A0-A7      | 455335520     | 434E3130  | 00000000 | 30303033       |
|            | 000012BD      | 0162B1F1  | 00000000 | 00000000       |
| PC = 00001 | 00 C SR = 800 | 00        | ANDLB #5 | \$000000E0, SR |
| D0-D7      | 00218013      | 00038065  | 46495820 | 00000000       |
|            | 20202020      | 20202020  | 00000000 | 00000061       |
| A0-A7      | 45535520      | 434E3130  | 00000000 | 30303033       |
|            | 000012BD      | 0162B1F1  | 00000000 | 00000000       |
| PC = 00001 | 010  SR = 800 | 00        | ADD D0.  | , D1           |
| D0-D7      | 00218013      | 00030078  | 46495820 | 00000000       |
|            | 20202020      | 20202020  | 00000000 | 00000061       |
| A0-A7      | 45533520      | 434E3130  | 00000000 | 30303033       |
|            | 000012BD      | 0162B1F1  | 00000000 | 00000000       |
| PC = 00001 | 012  SR = 802 | 13 EN     | D        |                |

#### Beispiel 3:

MOVE.B #\$80,D1 (Úbertrage das Byte \$80 nach D1)

#### Vor der Ausführung:

$$D1=$17832428 \text{ und } CCR-$17 (X=1, N=0, Z=V=C=1))$$

### Ausführung:

\$80 wird anstelle von \$28 in D1 geschrieben.

Nach der Ausführung:

Durch den MOVE-Befehl werden V und C auf 0 zuruckgesetzt. X bleibt von der Übertragung unbeeinflußt und ist weiterhin 1. N wird auf 1 gesetzt, denn das höchstwertige Datenbit ist 1.

### Beispiel 4:

NOT.L D0 (Bilde das Einerkomplement von D0)

Von der Ausführung:

D0=\$02110443 und CCR=\$00

### Ausführung:

D0-\$FDEEFBBC; das Ergebnis ist negativ, also wird N-1, und da das Ergebnis nicht 0 ist, wird Z=0 gesetzt.

Der Befehl NOT veranlaßt, daß die Bedingungscodes C und V auf 0 zuruckgesetzt werden und das Bit X unverändert bleibt.

Nach der Ausführung:

D0=\$FDEEFBBC und CCR=\$08

Beispiel 5:

ADDA.W D0,A0 (Addition des erweiterten Wortes D0 zu A0)

Vor der Ausführung:

A0=\$00002250, D0=\$00008020, CCR=\$17

Ausführung:

FFFF8020 +00002250 FFFFA270

Nach der Ausführung:

A0=\$FFFFA270, D0=\$00008020, CCR=\$17

Der Befehl ADDA läßt alle Bedingungscodes unverändert.

Abschließend kann man über das Setzen der Bedingungscodes folgendes sagen:

Das Setzen ist von dem jeweiligen Befehl abhängig (ADD setzt die üblichen Bedingungscodes bei einer Addition, während ADDA alle Codes unverändert läßt).

- Die Codes stehen in Beziehung zur Länge der Operanden.

### **DIE ADRESSIERUNGSARTEN**

Der Mikroprozessor MC68000 besitzt 14 unterschiedliche Adressierungsarten, die man in 6 Gruppen einteilen kann:

Absolut
 Absolut kurz
 Absolut lang

- Register direkt
   Datenregister direkt
   Adreßregister direkt
   Statusregister direkt
- Unmittelbar
   Unmittelbar einfach
   Unmittelbar schnell

Register indirekt
Adreßregister indirekt
Adreßregister indirekt
mit Postinkrement
Adreßregister indirekt
mit Predekrement
Adreßregister indirekt
mit Adreßdistanz
Adreßregister indirekt
mit Index und Adreßdistanz

Relativ zum Programmzähler
Relativ mit Adreßdistanz
Relativ mit Index und Adreßdistanz

Wir werden nun die verschiedenen Adressierungsarten betrachten, indem wir ihre Definition geben und sie anhand von Beispielen veranschaulichen.

#### ABSOLUTE ADRESSIERUNG

Bei diesem Adressierungstyp ist die effektive Adresse selbst als Operand spezifiziert.

Bei der "absolut kurzen" Adressierung ist der Operand eine 16-Bit-Adresse. Sie erlaubt entweder auf die ersten 32 KByte oder auf die höchsten 32 KByte im Speicher zuzugreifen und erfordert ein Erweiterungswort.

 Bei der "absolut langen" Adressierung ist der Operand eine 32 Bit Adresse. Sie erlaubt den Zugriff auf irgendeinen Speicherplatz der 16-MByte-Speichers des 68000 und erfordert zwei Erweiterungsworte

### Absolut kurze Adressierung

### Prinzipielle Arbeitsweise:



Wir wollen uns nun Beispiele für absolut kurze Adressierung ansehen.

#### Beispiel 1:

NOT.L \$2000 (Bilde das Einerkomplement des Doppelwortes, das ab der Adresse \$2000 gespeichert ist)

#### Befehlscode:



Der Befehlscode entspricht also dem hexadezimalen Wert \$46B8.



Wenn wir uns den Speicher anschauen, sehen wir folgendes:

Beispiel 2:

MOVE.W \$1000,\$2000 (Übertrage das Wort von Adresse \$1000 zur Adresse \$2000)

Das Format des MOVE Befehls sieht folgendermaßen aus:



Abb. 4.2: Format des MOVE-Befehls

Um diesen Befehl als Code schreiben zu können, muß man die Tabellen für die Operationscodes und für die Adressierungsarten zu Hilfe nehmen.

# Tabelle der Operationscodes:

| Bits 12 bis 15 | Operation                           |
|----------------|-------------------------------------|
| 0000           | Bitmanipulation, MOVEP, unmittelbar |
| 00011          | MOVE Bytes                          |
| 0010           | MOVE Doppelworte                    |
| 0011           | MOVE Worte                          |
| 0100           | Andere Befehle                      |
| 0101           | ADDQ, SUBQ, Scc, DBcc               |
| 0110           | Bcc, BSR                            |
| 0111           | MOVEQ                               |
| 1000           | OR, DIV, SBCD                       |
| 1001           | SUB, SUBX                           |
| 1010           | unbenutzt                           |
| 1011           | CMP, EOR                            |
| 1100           | AND, MJL, ABCD, EXG                 |
| 1101           | ADD, ADDX                           |
| 1110           | Schiebe- und Rotierbefehle          |
| 1111           | unbenutzt                           |

# Tabelle der Adressierungsarten:

| Adressierungsmodus                | Modus | Register             |
|-----------------------------------|-------|----------------------|
| Datenregister direkt              | 000   | Nummer des Registers |
| Adreßregister direkt              | 001   | Nummer des Registers |
| Adreßregister indirekt            | 010   | Nummer des Registers |
| Adreßregister indirekt mit Post   |       |                      |
| inkrementation                    | 011   | Nummer des Registers |
| AdreBregister Indirekt mit Prede- |       |                      |
| krementation -                    | 100   | Nummer des Registers |
| AdreBregister indirekt mit AdreB- |       | _                    |
| distanz                           | 101   | Nummer des Registers |
| Adreßregister indirekt mit Index  | 110   | Nummer des Registers |
| Absolut kurz                      | 111   | 000                  |
| Absolutlang                       | 111   | 001                  |
| Relativ zum Programmzähler        |       |                      |
| m t Adreßdistanz                  | 111   | 010                  |
| Relativ zum Programmzähler        |       |                      |
| mit Index                         | 111   | 011                  |
| Statusregister unmittelbar        | 111   | 100                  |

# Also sieht der Befehlscode für MOVE folgendermaßen aus:



Der hexadezimale Code dieses Befehls lautet:

31F8 1000 2000

Wir finden diesen Code im folgenden Assembler-Programm wieder:

00001000 ORG \$1000 00001000 31F810002000 MOVE.W \$1000, \$2000 END

TOTAL ERRORS 0 TOTAL WARNINGS 0



Natürlich können nur bestimmte Adreßbereiche mit absolut kurzer Adressierung beschrieben werden, da die 32-Bit-Adresse durch die vorzeichenbehaftete Erweiterung auf 32 Bits erhalten wird.

| 32 Bits  | Darstellung der unteren 16 Bits einer 32-Bit-Adresse |
|----------|------------------------------------------------------|
| 00000000 | 0000                                                 |
| 00007FFF | 7F#F                                                 |
| 00008000 | Darstellung als absolut kurze Adresse                |
| FFFF7FFF | nicht möglich                                        |
| FFFF8000 | 8000                                                 |
| FFFFFFF  | FFFF                                                 |

# Absolute lange Adressierung

Prinzipielle Arbeitsweise:



Beispiel für absolut lange Adressierung:

NOT.L \$032000

Das Befehlsformat für den Befehl NOT zur Bildung des Einerkomplements wird in Abb. 4.3 dargestellt.



Abb. 4.3: Format des Befehls NOT

#### Befehlscode:

| 0 | 1 | 0 | 0 | 0 | 1 | 1   | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0  | 1 |
|---|---|---|---|---|---|-----|---|---|---|---|---|---|---|----|---|
|   |   |   |   |   |   | L . |   | ĺ |   |   |   |   |   | Ι. | ] |

#### Hexadezimalcode des Befehls:

46B9 0003

2000

# Ausgeführte Aktion:

|    | Speicher |   |
|----|----------|---|
| 15 |          | C |
|    |          |   |
|    | 4 6 B 8  |   |
|    | 0003     |   |
|    | 2000     |   |
|    |          |   |

\$32000 und \$32001:

\$32002 und \$32003:

1 1 0 0 -- EEFF 0 0 0 0 -- FFFF

#### DIREKTE REGISTERADRESSIERUNG

Bei dieser Adressierungsart ist der Operand in einem angegebenen Register als effektive Adresse (EA) enthalten.

#### **Datenregister**

Dieses Register ist eines der acht 32-Bit-Register Dn. Wir können also schreiben

EA = Dn

Dn: Operand

#### Beispiel:

NOT D6 (Bilde das Einerkomplement für das Wort im Register D6)

Wenn kein Datenlängencode angegeben ist, wird als Standardwert .W angenommen.

#### Befehlscode:



#### Hexadezimalcode:

4646



Für bestimmte Befehle, die zwei effektive Adressen benötigen, z. B. MOVE, ist es möglich, Adressierungsarten zu kombinieren.

### Beispiel:

Wir zeigen die gemischte Verwendung der direkten Adressierung des Datenregisters und der absolut kurzen.

MOVE D0,\$1E66 (Übertrage die 16 unteren Bits von D0 zur Adresse \$1E66)

#### Befehlscode:

|  |  | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|--|--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|--|--|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

#### Hexadezimalcode:

31C0 1E66



Es folgt ein anderes Beispiel, bei dem das Datenregister das Ziel der Übertragung ist.

MOVE. W \$2000, D3 (Übertrage das an Adresse \$2000 stehende Wort ins Datenregister D3)

#### Befehlscode:



### Hexadezimalcode:

3638



# Adreßregister

Es gibt sieben 32-Bit-lange Adreßregister An.

An: Operand

### Beispiel:

Das Adreßregister ist der Zieloperand einer Übertragung.

MOVE \$305040,A2

### Befehlscode:



#### Hexadezimalcode:

3479 0030 5040



Bitte vergessen Sie nicht, daß bei der Verwendung des Adreßregisters als Zieloperand eine vorzeichenbehaftete Erweiterung erfolgt, wenn es sich um eine Wortoperation handelt.

### Beispiel:

Das Register An ist im folgenden der Quelloperand.

MOVE.L A2,D3 (Übertrage das Doppelwort aus A2 nach D3)

#### Befehlscode:





### Statusregister

Folgende privilegierte Befehle verwenden die direkte Adressierung:

- ANDI mit SR
- EORI mit SR
- ORI mit SR
- MOVE mit SR

#### Schreibweise:

EA-SR

SR: Operand

### Beispiel:

ANDI #\$0040, SR

#### Befehlscode:



#### Hexadezimalcode:

027C 0040



#### UNMITTELBARE ADRESSIERUNG

Bei dieser Adressierungsart wird der Operand dem Befehl als Konstante mitgegeben.

#### Einfache unmittelbare Adressierung

Der Operand wird in dem unmittelbar dem Befehlscode folgenden oder den zwei nächsten Worten angegeben.



Schreibweise: Unmittelbar xxxx wird als #xxxx angegeben.

#### Beispiel:

MOVE #\$FFFF,D0

#### Refehlscode:





Wenn der Befehl folgendermaßen gelautet hätte:

wurde nach der Ausführung das Register A0 den Wert FFFFFFF wegen der vorzeichenbehafteten Erweiterung enthalten.

# Schnelle unmittelbare Adressierung

Bei diesem Typ ist die Konstante in den unteren 8 Bits des Befehlswortes selbst enthalten. Daher darf sie nicht länger als 8 Bits sein.

| 15 |                | 8 7 | 0           |
|----|----------------|-----|-------------|
|    | Operationscode |     | 8-Bit-Daten |

#### Beispiel:

MOVEQ #\$80,D0 (Move Quick) (Ubertrage \$80 schnell nach D0 im Anschluß an die vorzeichenbehaftete Erweiterung von \$80)

#### Befehlsformat von MOVEO:



# Befehlscode:

|   | 0 | 1 1 | 1 | 1 | 0 ' | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|---|---|-----|---|---|-----|---|---|---|---|---|---|---|---|---|---|---|
| ı |   | i   |   |   |     |   |   |   |   |   |   |   | İ | l |   | ! |

### Beim Assemblieren des Befehls ergibt sich:

| 00001000<br>WARNING 500 | 00001000<br>7080 | ORG<br>MOVEQ | \$1000<br># \$80, D0 |
|-------------------------|------------------|--------------|----------------------|
|                         |                  | END          |                      |
| TOTAL ERRORS            | 0                |              |                      |
| TOTAL WARNINGS          | 1                |              |                      |

Die Warnung im Assembler-Programm deutet darauf hin, daß eine vorzeichenbehaftete Erweiterung vorgenommen wurde.



Ein anderes Beispiel:

00001000 7070 ORG MOVEQ \$1000 # \$70, D0

00001000

7070

END

TOTAL ERRORS 0
TOTAL WARNINGS 0

# ADRESSIERUNGSART ADRESSREGISTER INDIREKT

Im allgemeinen zeigt bei der indirekten Adressierungsart der Inhalt des Adreßregisters auf einen Operanden.

# Adreßregister indirekt einfach

Bei dieser Art zu adressieren enthält das Adreßregister die effektive Adresse selbst.

Schreibweise:

$$EA=(An)$$

Der Inhalt von An enthalt die wirkliche Adresse des Operanden.



# Beispiel:

MOVE (A0),D0 (Übertrage das Wort, das an der mit A0 adressierten Speicheradresse steht, nach D0)







# Adreßregister indirekt mit Postinkrement

Das im Befehl angesprochene Adreßregister enhält die Adresse des Operanden. Wenn das Datenelement gefunden wurde, wird das Register An um N erhöht.

Dabei kann N folgende Werte annehmen:

N=1, wenn der Operand ein Byte ist

N=2, wenn der Operand ein Wort ist

N=4, wenn der Operand ein Doppelwort ist

#### Schreibweise:

$$EA=(An)$$
 und  $An=An+N$ 



Wir kennzeichnen die Postinkrementierung durch das + Zeichen. Beispiele:

MOVE.W D0,(A0)+ ADD.L D4,(A1)+ MOVE (A0)+,\$1000 Dieses letzte Beispiel wollen wir noch etwas näher betrachten.

#### Befehlscode:



Das Register A0 enthält die Adresse des Operanden: \$0440.

Einerseits wird das Wort mit dem Inhalt \$0500 an der Adresse \$0440 gelesen und eine Kopie davon an die Adresse \$1000 geschrieben. Andererseits wird die Adresse \$0440 um 2 erhöht, da der MOVE-Befehl eine Wortoperation war. Auf diese Weise enthält A0 am Ende der Übertragung die Adresse \$00000442.

# Adreßregister indirekt mit Predekrement

Das Adreßregister An enthält eine Speicheradresse. Diese Adresse muß um N dekrementiert werden, um beispielsweise einen benachbarten Operanden anzusprechen.

N=1, wenn der Operand ein Byte ist

N=2, wenn der Operand ein Wort ist

N=3, wenn der Operand ein Doppelwort ist

#### Schreibweise:



Die Vordekrementierung wird durch ein Minus-Zeichen gekennzeichnet. Beispiele:

Das letzte Beispiel wollen wir uns wieder genauer ansehen.

#### Befehlscode:





Das Adreßregister A1 enthält die Speicheradresse \$00001200. Diese Adresse wird um 2 vermindert, denn der MOVE-Befehl ist hier eine Wortoperation. A1 ist nun also \$000011FE.

An dieser Adresse finden wir den Operanden \$4358, dessen Kopie an die Adresse \$3000 übertragen werden soll.

# Bedeutung der Nachinkrementierung bzw. Vordekrementierung

Diese beiden Adressierungsarten erlauben dem Prozessor, auf sehr einfache Weise Stapelverarbeitung zu realisieren und Tabellen, Datenfolgen oder Warteschlangen zu bearbeiten.

# Definition 1:

Ein Stapel (Stack) ist ein Speicher oder Speicherbereich, bei dem die zuletzt abgelegte Information als erstes wieder ausgelesen wird (LIFO: Last In, First Out).



#### Definition 2:

Eine Warteschlange (Queue) ist ein Speicher oder Speicherbereich, bei dem die zuerst abgelegte Information auch als erstes wieder ausgelesen wird (FIFO: First In, First Out).



# Aufbau und Verwendung von Stapeln

Um eine Stapelstruktur zu realisieren, verwendet man hauptsachlich die Adressierungsarten "Adreßregister indirekt mit Postinkrementierung" (An)+ und "Adreßregister indirekt mit Predekrementierung" –(An), wobei die Adreßregister A0, …, A6 die Stapelzeiger darstellen. Dieser Stapel kann von niedrigen zu hohen Adressen gefüllt werden oder umgekehrt.

Der aufsteigende Stapel: Schreiben von hohen zu niedrigen Adressen

Um diesen Stapel zu erzeugen, benötigt man

die Vordekrementierung zum Füllen des Stapels;
 die Nachinkrementierung zum Leeren des Stapels.

Angenommen unser Stapel soll im Speicherbereich \$1000 bis \$1009 liegen, und er soll mit Bytes gefüllt werden (Abb. 4.4).



Abb. 4.4: Organisation eines aufsteigenden Stapels

Da der Stapel aufsteigend ist, liegt das zuerst eingetragene Element unten, und wir müssen daher das Register An mit \$1009 initialisieren.

Im folgenden wird ein Befehl zur Vordekrementierung gegeben, damit An auf \$1008 gesetzt wird, um das Datenelement A dort eintragen zu können.

Die nächstfolgende Predekrementierung bringt An auf \$1007 und schreibt das Datenelement B dort hinein.

Auf diese Weise wird ein aufsteigend gefüllter Stapel realisiert.

Bemerkung: Bei diesem Stapelbetrieb ist die letzte Stelle immer leer. Das Adreßregister zeigt immer auf das zuletzt eingetragene Datenelement.

Wenn das siebte Datenelement G eingetragen ist, enthält das Adreßregister also den Wert \$1002. Falls wir jetzt den Stapel wieder auslesen wollen, muß notwendigerweise G zuerst herausgenommen werden Danach wird An erhöht, um das folgende Datenelement lesen zu können. Es handelt sich hierbei um eine Postinkrementierung.

Der absteigende Stapel: Schreiben von niedrigen zu hohen Adressen.

Um diesen Stapel zu erzeugen, füllt man ihn in Richtung der aufsteigenden Adressen.

Wir greifen das vorhergehende Beispiel auf. Im jetzt vorliegenden Fall entspricht die Adresse \$1000 dem Stapelboden und \$1009 der Stapelspitze (Abb. 4.5)



Abb. 4.5: Organisation eines absteigenden Stapels

Damit nun die erste Dateneinheit an die Adresse \$1000 geschrieben wer den kann, muß An mit \$1000 initialisiert werden, worauf dann eine Nachinkrementierung durchgeführt wird. Das Datenelement wird an die Adresse \$1000 geschrieben, und danach wird An erhöht. Der Zeiger wird für die Speicherung des nächsten Datenelementes gesetzt

Bemerkung: An zeigt stets auf das Stapelfeld, das als nachstes beschrie ben werden soll Also wenn man den Stapel jetzt wieder auslesen will, zeigt das Register An noch auf \$1006, und das zuletzt geschriebene Datenelement befindet sich an der Adresse \$1005. Daher muß An vermindert werden, um an diesen Wert zu gelangen.

Damit der Stapel gelesen werden kann, muß zuvor eine Predekrementierung durchgeführt werden.

Zusammenfassend kann man sagen, daß bei diesem Stapelbetrieb folgendermaßen vorgegangen wird:

- Postinkrementierung, um den Stapel zu füllen.
- Predekrementierung, um den Stapel zu leeren.

# Aufbau und Verwendung von Warteschlangen

Die Warteschlangen (Queues) können wie die Stapel in aufsteigender oder absteigender Richtung verwaltet werden. Um solche Datenfolgen zu erzeugen, werden notwendigerweise zwei Adreßregister benutzt; eins zeigt auf das Ende der Warteschlange, wo die neuen Daten eingetragen werden, das andere zeigt auf den Anfang, wo die Daten zuerst entnommen werden.

# Die aufsteigende Warteschlange

Dieser Warteschlangentyp wird folgendermaßen realisiert:

- Predekrementierung, um neue Daten in die Warteschlange einzureihen;
- Postinkrementierung, um Daten aus der Warteschlange zu entnehmen.

Die beiden Register An und An' werden jeweils in die gleiche Richtung verändert. Dabei werden sie aber vollkommen unabhängig voneinander verwaltet.

# Nach einem Schreibvorgang:

- An zeigt auf die zuletzt eingetragene Dateneinheit in der Warte schlange.
- An' zeigt unverändert auf die letzte Dateneinheit, die die Warteschlange verlassen hat.

# Nach einem Lesevorgang:

 An zeigt unverändert auf die letzte Dateneinheit, die in die Warteschlange eingereiht worden ist.



Abb 46: Organisation einer aufsteigenden Warteschlange

 An' zeigt auf die letzte Dateneinheit, die die Warteschlange verlassen hat.

Dieser Vorgang wird noch einmal in der Abb. 4.6 verdeutlicht, die auf den vorangehenden Beispielen basiert.

# Die absteigende Warteschlange

Sie wird folgendermaßen realisiert:

- Postinkrementierung, um die Warteschlange zu füllen;
- Postinkrementierung, um die Warteschlange zu leeren.

Auf diese Weise wird das Register An dazu benutzt, um Daten in der Warteschlange abzulegen, und An', um Daten aus ihr zu entnehmen. An und An' werden vollkommen unabhängig voneinander verwaltet.

### Nach einem Schreibvorgang:

An zeigt auf das nächste verfügbare Warteschlangenfeld
 An' zeigt unverändert auf das Feld, aus dem zuletzt ein Datenelement entnommen wurde.

### Nach einem Lesevorgang:

An zeigt unverändert auf das nächste freie Warteschlangenfeld.

- An' zeigt auf das zuletzt ausgegebene Warteschlangenfeld.

Dieser Vorgang wird durch Abb. 4.7 verdeutlicht.



Abb. 4.7: Organisation einer absteigenden Warteschlange

# Adreßregister indirekt mit Verschiebung

Die Operandenadresse ergibt sich aus der Summe der Adresse im Adreßregister plus dem 16-Bit-Adreßdistanzwert im vorzeichenbehafteten Erweiterungswort.

#### Schreibweise:

EA-(An)+D; D ist der Adreßdistanzwert



Die Verschiebung wird vor dem Register An angegeben.

# Beispiele:

Das letzte Beispiel wollen wir wieder näher erläutern.

#### Befehlscode:



#### Hexadezimalcode:

31E8 0300 1000



#### Berechnen der Adresse:

Der MOVE-Befehl veranlaßt den Prozessor, die Dateneinheit zu übertragen, wobei in diesem Fall ein Wort von der errechneten Quelladresse \$0800 nach \$1000 kopiert wird. Die Berechnung der Adresse ist durch Addition der Adresse A0 mit Adreßdistanzwert \$300 erfolgt.

Bei der Zieladresse \$1000 handelt es sich um eine absolut kurze Adresse.

Diese Adressierungsart gestattet es, den Speicher entsprechend einer festen Adresse anzusprechen, um ein Datenelement relativ zu einer Basisadresse aufzufinden.

### Adreßregister indirekt mit Index und Adreßdistanzwert

Die Operandenadresse ergibt sich aus der Summe der Adresse im Adreßregister, dem 8-Bit-Adreßdistanzwert aus dem niederwertigen Teil des Erweiterungswortes und dem Inhalt des Indexregisters.

#### Schreibweise:

$$EA = (An) + D + (Ri)$$
; Ri ist das Indexregister



Diese Adressierungsart erfordert ein Erweiterungswort, dessen Aufbau in der Abb. 4.8 dargestellt wird.



D/A = 0: Das Indexregister ist ein Datenregister.

D/A = 1: Das Indexregister ist ein Adreßregister.

W/L = 0: Der Inhalt des Indexregisters ist ein Wort.

W/L = 1: Der Inhalt des Indexregisters ist ein Doppelwort.

Abb. 4.8 Aufbau eines Erweiterungswortes bei indirekter indizierter Adressierung

Das Bit 11, das W/L genannt wird, gibt die Indexgröße an.

Im Falle eines 16-Bit-Index schreibt man

Ri.W oder Ri

Bei der Berechnung der tatsächlichen Adresse wird eine vorzeichenbehaftete Erweiterung des Index auf 32 Bit vorgenommen.

Im Falle eines 32-Bit-Index schreibt man

Ri.L

Beispiel:



Folgendes Beispiel wollen wir näher betrachten:

Das erste Wott hat folgende Darstellung:



Das zweite Wort hat folgende Darstellung:



Hexadezimalcode:

11F1 0002 2000 Befehlsbeschreibung: Der zu übertragende Operand ist ein Byte. Der Befehl veranlaßt den Prozessor, die effektive Adresse des Operanden, ausgehend von der Verschiebung 2, dem Adreßregister A1 und dem Indexregister D0 zu berechnen.

Danach wird der Inhalt des so adressierten Speicherfeldes zur absoluten Adresse \$2000 gebracht.

Berechnung der effektiven Adresse:



Vorteile dieser Adressierungsart: Oft ist es notwendig, auf den Inhalt einer Tabelle im Speicher zugreifen zu können. Man wählt dann ein Adreßregister, das z. B. die Basisadresse dieser Tabelle enthält. Die einfache indizierte Adressierung (wobei der Adreßdistanzwert D-0 ist) ermöglicht dann, zur Basisadresse einen Index zu addieren, so daß jeweils auf das n-te Element der Tabelle (Byte, Wort oder Doppelwort) zugegriffen werden kann Mit Hilfe des Adreßdistanzwertes ist es dann möglich, relativ zu einer Tabelle weitere zu erzeugen.

#### ADRESSIERUNGSARTEN RELATIV ZUM PROGRAMMZÄHLER

Bei dieser Adressierungsart ist die effektive Adresse eine Funktion des Wertes des Programmzählers und eines 16-Bit-Distanzwertes.

Es gibt zwei Arten von relativer Adressierung: relative Adressierung, bezogen auf den Programmzähler, und relativ indizierte Adressierung, bezogen auf den Programmzähler.

Der Sinn der relativen Adressierung liegt darin, eine einfache Verschiebbarkeit und Positionsunabhängigkeit zu erreichen. Außerdem wird durch Vereinfachung der Referenzbezüge zu Nachbaradressen des aktuell bearbeiteten Befehls die erforderliche Befehlslänge deutlich verringert.

# Relative Adressierung, bezogen auf den Programmzähler, mit Adreßdistanz

Alle Befehle, die die Programmzähler-relative Adressierung verwenden, benötigen ein Erweiterungswort, um den 16-Bit-Adreßdistanzwert aufzunehmen. Eine Ausnahme bilden dabei die Verzweigungsbefehle, bei denen ein 8-Bit-Adreßdistanzwert einen Teil des Befehlswortes selbst ausmacht.

Dieses Distanzwort wird zum Zeitpunkt der Assemblierung errechnet, wenn zuvor die relative Startadresse des Programmteils mit Hilfe einer speziellen Assembler-Anweisung festgelegt wurde (siehe auch RORG).

Schreibweise:

$$EA = (PC) + D16$$

Format von Befehlen mit relativer Adressierung:



Zum Zeitpunkt der Ausfuhrung eines solchen Befehls zeigt der Befehlszähler schon auf das folgende Wort, das den Distanzwert enthält. Der Zugriff auf den Distanzwert kann mit dem folgenden Schema dargestellt werden.



# Beispiele für relative Adressierung mit Distanzwert:

Folgendes Programm wird zugrundegelegt:

| \$1000<br>\$1004<br>\$1006 | RORG<br>MOVE<br>NOP<br>NOP | \$1000<br>VERSUCH, D1 | ; NO oPeration                                              |
|----------------------------|----------------------------|-----------------------|-------------------------------------------------------------|
| \$1008<br>\$100A VERSUCI   | 2.0.                       | \$3030                | ; Konstante<br>; definieren,<br>; Assembler-<br>; direktive |
|                            | END                        |                       |                                                             |

#### Befehlscode von MOVE VERSUCH.D1:



Berechnung des Distanzwertes: Die Adresse des Distanzwertes ist \$1002. Es muß die Adresse \$100A des LabelsVERSUCH angesprungen werden. Der Adreßdistanzwert muß daher \$0008 betragen. Das Programm sieht jetzt mit Hex-Codes folgendermaßen aus:

|        |          |         | RORG | \$1000      |
|--------|----------|---------|------|-------------|
| \$1000 | 323A0008 |         | MOVE | VERSUCH, D1 |
| \$1004 | 4E71     |         | NOP  | ,           |
| \$1006 | 4E71     |         | NOP  |             |
| \$1008 | 4E71     |         | NOP  |             |
| \$100A | 3030     | VERSUCH | DC   | \$3030      |
|        |          |         | END  |             |

Auf diese Weise ist das Label relativ zur Adresse \$1002 festgelegt worden, die die aktuelle Adresse im Programmzähler zum Zeitpunkt der Ausführung des MOVE-Befehls darstellt. Schließlich bewirkt der MOVE-Befehl, daß der Wert \$3030 nach D1 geladen wird. Wir stellen fest, daß das Label VERSUCH nach dem MOVE-Befehl festgelegt wird, was die Errechnung des Adreßdistanzwertes vereinfacht.

Wir greifen nochmals das gleiche Beispiel auf Diesmal jedoch wollen wir die Adresse des Labels VERSUCH vor dem MOVE Befehl festlegen

|        |         | RORG | \$1000      |
|--------|---------|------|-------------|
| \$1000 | VERSUCH | DC   | \$3030      |
| \$1002 |         | NOP  |             |
| \$1004 |         | NOP  |             |
| \$1006 |         | NOP  |             |
| \$1008 |         | MOVE | VERSUCH, D1 |
|        |         | END  |             |
|        |         |      |             |

Was den MOVE Befehl betrifft, ist der Operationscode und die Angabe der effektiven Adresse die gleiche geblieben. Allerdings hat sich der Betrag des Distanzwertes verändert.

Der Distanzwert muß nun von der Adresse \$100A (die aktuelle Adresse zum Zeitpunkt der Ausführung des MOVE-Befehls) abgezogen werden, damit das Label an der Adresse \$1000 aufgefunden werden kann.

Der Adreßabstand zwischen dem MOVE-Befehl und dem Label beträgt \$000A; es genügt also, das Zweierkomplement dieses Wertes zu bilden, um den neuen Adreßdistanzwert zu erhalten.

#### Testrechnung:

Adresse im PC \$0000100A

Adreßdistanz \$FFFFFF6 \$00001000

Das zugehorige Programm sieht also folgendermaßen aus:

|        |          |         | RORG | \$1000      |
|--------|----------|---------|------|-------------|
| \$1000 | 3030     | VERSUCH | DC   | \$3030      |
| \$1002 | 4E71     |         | NOP  |             |
| \$1004 | 4E71     |         | NOP  |             |
| \$1006 | 4E71     |         | NOP  |             |
| \$1008 | 323AFFF6 |         | MOVE | VERSUCH, D1 |
|        |          |         | END  |             |

Um die Rolle des Assembler-Befehls RORG deutlich zu machen, lassen wir das erste Beispiel noch einmal mit dem Befehl ORG zu Beginn assemblieren.

|        |         | ORG  | \$1000      |
|--------|---------|------|-------------|
| \$1000 |         | MOVE | VERSUCH, D1 |
| \$1004 |         | NOP  |             |
| \$1006 |         | NOP  |             |
| \$1008 |         | NOP  |             |
| \$100A | VERSUCH | DC   | \$3030      |
|        |         | END  |             |

#### Befehlscode von MOVE VERSUCH,D1:



#### Hexadezimatcode:

3238

100A (Adresse von VERSUCH)

Das Programm sieht dann so aus:

|        |          |         | ORG  | <b>\$</b> 1000 |
|--------|----------|---------|------|----------------|
| \$1000 | 3238100A |         | MOVE | VERSUCH, D1    |
| \$1004 | 4E71     |         | NOP  |                |
| \$1006 | 4E71     |         | NOP  |                |
| \$1008 | 4E71     |         | NOP  |                |
| \$100A | 3030     | VERSUCH | DC   | \$3030         |
|        |          |         | END  | ·              |

#### Spezialfall: Verzweigungsbefehle

Bei den bedingten Verzweigungen wird, wenn die festgelegte Bedingung eintritt, die Ausführung des Programms an der Adresse (PC)+Adreßdistanzwert fortgesetzt. Andernfalls läuft das Programm fortlaufend ab.

Für alle Verzweigungsarten kann der Adreßdistanzwert in 8 Bit verschlüsselt werden.

Wenn die Adreßdistanz im Besehlswort den Wert 0 hat, bedeutet das, daß der Adreßdistanzwert im Erweiterungswort in 16 Bits verschlüsselt ist.

#### Beispiel 1:

\$2000

**BCC** 

PROG1

\$2010

PROG1

NOP

Bedeutung des Beschls BCC: Wenn das Carry-Bit 0 ist, verzweigt der Prozessor zur Adresse PROG1, andernfalls setzt er die Verarbeitung mit dem nächsten Beschl fort.

#### Befehlscode:





Beispiel 2:

\$1000

BEQ

PROG1

\$2010 PROG1 NOP

Bedeutung des Befehls BEQ: Es wird zur Adresse \$2010 verzweigt, wenn die Uberprüfung auf Gleichheit erfolgreich war, d. h. wenn der Bedingungscode Z=1 ist.

#### Befehlscode:



#### Code des Erweiterungswortes:

Adresse der Verzweigung:

\$2010

Wert von PC:

-\$1002

Adreßdistanzwert:

\$100E 16 Bits



#### Relative Adressierung mit Index, bezogen auf den Programmzähler

Die Operandenadresse ist die Summe des Wertes, der im Programmzähler enthalten ist, dem Wert aus dem Indexregister und einem 8-Bit-Adreßdistanzwert.

Schreibweise:

$$EA-(PC)+(Ri)+D8$$

Diese Adressierungsart benötigt ein Erweiterungswort, dessen Aufbau in Abb. 4.9 zu sehen ist.



#### bit 151

D/A = 0: Das Indexregister ist ein Datenreg ster.

D/A = 1. Das Indexregister ist ein Adreßreg ster.

#### bit 11:

 $W/L=0. \ \ Das\ Indexregister\ enthält\ ein\ Wort,\ das\ auf\ 32\ Bit\ vorzeichenerweitert\ werden\ muB.$ 

W/L = 11 Das Indexregister enthält ein Doppelwort

Abb. 4.9. Format des Erweiterungswortes bei der relativen Adressierung mit Index

#### Prinzipielle Arbeitsweise dieser Adressierungsart:



#### Beispiel:

ist 0. Das Register enthält ein Wort

|             | RORG    | \$1000           |
|-------------|---------|------------------|
| \$1000      | MOVE    | VERSUCH (A0), D1 |
| \$1004      | NOP     |                  |
| \$1006      | NOP     |                  |
| \$1008      | NOP     |                  |
| \$100A VERS | SUCH DC | \$3030           |
|             | END     |                  |

### Befehlscode von MOVE VERSUCH (A0),D1:



(\$100A-\$1002 = 8)

#### Hexadezimalcode:

323B 8008

Das zugehörige Programm sieht folgendermaßen aus

|                | RORG | \$1000          |
|----------------|------|-----------------|
| \$1000         | MOVE | VERSUCH(A0), D1 |
| \$1004         | NOP  |                 |
| \$1006         | NOP  |                 |
| \$1008         | NOP  |                 |
| \$100A VERSUCH | DC   | \$3030          |
|                | END  |                 |

Wenn das Register A0 den Wert 0 enthält, wird das Datenelement \$3030 in das Register D1 geschrieben. Wenn A0 von 0 verschieden ist, wird ein anderer Wert in D1 geschrieben.

Bei diesem Adressierungstyp muß man auch beachten, daß das Label (VERSUCH in unserem Fall) als Anfangsadresse einer Datenfolge betrachtet wird, in der man Informationen mit Hilfe des Indexregisters A0 auffindet.



Eine zusammenfassende Tabelle der verschiedenen Adressierungsarten ist in Abb. 4.10 zu sehen.

| Adressierungsart                       | Syntax                                           | Effektive Adresse (EA)                                                               |
|----------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------|
| Absolut kurz                           | 16-Bit Adresse                                   | EA - 16-Bit-Adresse                                                                  |
| Absolutiang                            | 24-Bit-Adresse                                   |                                                                                      |
| Datenregister direkt                   | DN                                               | EA = DN                                                                              |
| Adreßregister direkt                   | AN                                               | EA – AN                                                                              |
| Statusregister direkt                  | SR                                               | EA = SR                                                                              |
| Unmittelbar                            | #Datenwert<br>16 oder 32 Bit                     | Keine Errechnung der effektiven<br>Adresse. Operand ist der Datenwert.               |
| Unmittelbar schneli                    | #8-B t-Datenwert                                 | Keine Errechnung der effektiven<br>Adresse Operand ist der Datenwert.                |
| Indirekt                               | (AN)                                             | EA = (AN)                                                                            |
| Indirekt mit Postin-<br>krementierung  | (AN)+                                            | 1. EA = (AN)<br>2. AN = AN + n (n = 1, 2, 4)                                         |
| Indirekt mit Prede-<br>krementierung   | -(AN)                                            | 1 AN = AN - n (n = 1, 2, 4)<br>2. EA = (AN)                                          |
| Indirekt mit Ver-<br>schiebung         | D16 (AN)                                         | EA (AN) + auf 32 Bit vorzeichen-<br>erweiterter 16-Bit-Adreßdistanzwert              |
| Indirekt indiz ert mit<br>Verschiebung | D8 (AN,R·)                                       | EA ~ (AN) + (R:) + auf 32 Bit vor-<br>zeichenerweiterter 8-Bit-Adreß-<br>distanzwert |
| Relativ (zum PC)                       | (PC)<br>abhängig von<br>Assembler-Anweisung      | EA = (PC) + auf 32 Bit vorzeichen-<br>erweiterter 16 Bit-Adreßdistanzwert            |
| Relativ (zum PC)<br>indiziert          | (PC) (R )<br>abhängig von<br>Assembler-Anweisung | EA = (PC) + (R:) + auf 32 Bit vor-<br>zeichenerweiterter 8-Bit-Adreß-<br>distanzwert |

Abb. 4.10. Die Adressierungsarten des MC68000

#### Übungen

- 4.1: Welche Länge darf der Operand eines Adreßregisters haben?
- 4.2: Angenommen wir haben es mit einer Wortoperation zu tun. Welche Rolle spielt das Register An, wenn es die Quelle der Operation bzw. wenn es das Ziel ist?
- **4.3:** Welche Länge hat der Adreßdistanzwert bei der indirekten Adressierung mit Adreßdistanz?

- 4.4: Welche Länge hat der Index bei der indizierten Adressierung?
- **4.5:** Welche Länge hat der Adreßdistanzwert bei der indirekten Adres sierung mit Index?
- **4.6:** Wann verwendet man die Adressierungsarten mit Postinkrementierung bzw. mit Predekrementierung?
- 4.7: Welchen Sinn hat die indizierte Adressierung?
- **4.8:** Ist die FIFO-Struktur bezeichnend für den Stapel- oder den Warteschlangenbetrieb?
- 4.9: Wie lang ist der Adreßdistanzwert bei der relativen Adressierung mit Adreßdistanz?
- **4.10:** Um wieviel wird bei der indirekten Adressierung mit Postinkrementierung erhöht, wenn es sich um eine Doppelwort-Operation handelt?

#### Lösungen

- **4.1:** Da bei Adreßregistern der Datenlängencode .B verboten ist, dürfen die Operanden nur Worte oder Doppelworte sein.
- **4.2:** An als Quelle: Die 16 niederwertigen Bits werden genommen. An als Ziel: Das gesamte Register wird verändert.
- 4.3: Der Adreßdistanzwert ist 16 Bits lang.
- **4.4:** Bei der indizierten Adressierung kann der Index ein Wort oder ein Doppelwort sein.
- 4.5: Bei der indirekten Adressierung mit Index beträgt die Länge des Adreßdistanzwertes 8 Bits
- **4.6:** Adressierung mit Postinkrementierung und Predekrementierung verwendet man bei der Stapel- und Warteschlangenverarbeitung.
- **4.7:** Indizierte Adressierung erlaubt den einfachen Zugriff zu Datenelementen in Tabellen.
- **4.8:** FIFO nennt man die Struktur bei einem Warteschlangenbetrieb, beim Stapelbetrieb war es die LIFO-Struktur.
- 4.9: Bei der relativen Adressierung beträgt die Länge des Adreßdistanzwertes 16 Bits, aber speziell bei Verzweigungsbefehlen nur 8 Bits
- 4.10: Die Erhöhung beträgt 4.

# Der Befehlssatz des 68000

Der Befehlssatz des Mikroprozessors 68000 umfaßt 56 Grundbefehle.

Jeder Befehl, abgesehen von einigen Ausnahmen, operiert mit Bytes, Worten oder Doppelworten. Außerdem kann der größte Teil der Befehle alle 14 Adressierungsarten benutzen.

Auf diese Weise – mit den verschiedenen Befehlstypen, den unterschiedlichen Daten und den Adressierungsarten – sind etwa 1000 unterschiedliche Befehlskombinationen möglich.

Dennoch braucht sich der Benutzer nur die mnemonische Schreibweise (sinnvolle Abkürzung) des Befehls zu merken, die Adressierungsart der Quelle und des Ziels je nach der Operation festzulegen und die Länge der Operanden anzugeben.

Was die interne Struktur des Prozessors betrifft, so ist sie sehr anpassungsfähig, da die Adreßregister mit verschiedenen Adressierungsarten arbeiten können (direkt, indirekt, indiziert etc.) und die Indexregister Daten- oder Adreßregister sein können. Andererseits ist jedes Register vollkommen unabhängig von den anderen.

Dank all dieser Eigenschaften ist der Befehlssatz leistungsstark, anpassungsfähig und ermöglicht somit eine effiziente Programmierung des MC68000.

Die Befehle lassen sich folgendermaßen in sieben Kategorien einteilen:

- Befehle für ganzzahlige Arithmetik
- Befehle für binärcodierte Dezimalarithmetik (BCD)
- logische Befehle
- Schiebe- und Rotierbefehle Bitmanipulationsbefehle
- Datentransportbefehle
- Systemsteuerbefehle

#### Logische Befehle

| Befehl | Länge des Operanden | Operation                             |
|--------|---------------------|---------------------------------------|
| AND    | 8, 16, 32           | DN UND (EA) → DN                      |
|        |                     | (EA) UND DN → EA                      |
|        |                     | (EA) UND #Dateneinheit → EA           |
| OR     | 8, 16, 32           | DNODER(EA) + DN                       |
|        |                     | (EA) ODER DN EA                       |
| 1      |                     | (EA) ODER #Dateneinheit → EA          |
| EOR    | 8, 16, 32           | (EA) EXKLUSIV-ODER Dy → EA            |
|        |                     | (EA) EXKLUSIV-ODER #Dateneinheit → EA |
| NOT    | 8, 16, 32           | Einerkomplement von (EA) - EA         |

#### Arithmetische Befehle

| Befehl         | Länge des Operanden    | Operation                                                                       |
|----------------|------------------------|---------------------------------------------------------------------------------|
| ADD            | 8, 16, 32              | DN + (EA) → DN<br>(EA) + DN → EA<br>(EA) + #Dateneinheit → EA<br>AN + (EA) → AN |
| ADX            | 8, 16, 32<br>16, 32    | $Dx + Dy + X \rightarrow Dx$ $(-(Ax)) + (-(Ay)) + X \rightarrow -(Ax)$          |
| CLR            | 8.16.32                | 0→FA                                                                            |
| CMP            | 8, 16, 32              | DN (EA)                                                                         |
|                |                        | (EA) - #Dateneinheit                                                            |
|                |                        | ((Ax)+) - ((Ay)+)                                                               |
|                | 16, 32                 | AN -(EA)                                                                        |
| DIVS           | 32/16                  | DN/(EA) → DN                                                                    |
| DIVU           | 32/16                  | DN/(EA) + DN                                                                    |
| EXT            | 8 16                   | Erweiterung von Bit 7 auf Bits 8 bis 15                                         |
|                | 16 32                  | Erweiterung von Brt 15 auf Bits 16 bis 31                                       |
| MULS  <br>MULU | 16 * 16 32             | DN*(EA) + DN                                                                    |
| NEG            | 16 * 16 32             | DN * (EA) → DN                                                                  |
| NEGX           | 8, 16, 32<br>8, 16, 32 | 0 - (EA) - EA                                                                   |
| SUB            | 8, 16, 32              | 0 – (EA) – X → EA<br>DN – (EA) → DN                                             |
| 002            | 0,10,32                | (EA) DN EA                                                                      |
|                |                        | (EA) #Dateneinheit +EA                                                          |
|                | 16,32                  | AN - (EA) → AN                                                                  |
| SUBX           | 8, 16, 32              | Dx - Dy - X + Dx                                                                |
|                |                        | (-(Ax)) - (-(Ay)) - X (Ax)                                                      |
| TAS            | 8                      | (EA) - 0 und Bit 7 von EA = 1                                                   |
| TST            | 8, 16, 32              | (EA) - 0                                                                        |

Abb. 5.1: Der Befehlssatz, gegliedert nach Typen

Bevor wir nun einige Befehle und Programmbeispiele detailliert betrachten, stellen wir eine vollständige Befehlsliste zusammen.

Diese Befehlsliste ist auch wieder in die schon erwähnten Kategorien eingeteilt, da dies bei der Erstellung eines Programms eine große Rolle spielt (Abb. 5.1).

#### Schiebe und Rotierbefehle

| Befehl | Länge des<br>Operanden | Operation |
|--------|------------------------|-----------|
| ASL    | 8, 16, 32              | X/C - 0   |
| ASR    | 8, 16, 32              | X/C       |
| LSL    | 8, 16, 32              | X/C - 0   |
| LSR    | 8, 16, 32              | 0 → X/C   |
| POL    | 8, 16, 32              |           |
| ROR    | 8, 16, 32              | - C       |
| ROXL   | 8, 16, 32              | C X       |
| ROXR   | 8, 16, 32              | x - C     |

#### Bittestbefehle

| Befehl | Länge des Operanden | Operation                                                             |
|--------|---------------------|-----------------------------------------------------------------------|
| BTST   | 8,32                | Test eines Bits von (EA) → Z                                          |
| BSET   | 8,32                | Test eines Bits von (EA) - Z<br>und Setzen des getesteten Bits auf 1. |
| BCLR   | 8,32                | Test eines Bits von (EA) → Z<br>und Setzen des getesteten Bits auf 0  |
| BCHG   | 8,32                | Test eines Bits von (EA) → Z<br>und Invertieren des getesteten Bits   |

Abb. 5.1: Der Befehlssatz, gegliedert nach Typen (Forts.)

#### Befehle für BCD-Arithmetik

| Befehl | Länge des Operanden | Operation                                                                        |
|--------|---------------------|----------------------------------------------------------------------------------|
| ABCD   | 8                   | $(Dx)_{10} + (Dy)_{10} + X \rightarrow Dx$                                       |
| SBCD   | 8                   | $-(Ax)_{10} + -(Ay)_{10} + X(Ax)$ $(Dx)_{10} - (Dy)_{10} - X - Dx$               |
| NBCD   | 8                   | $(Ax)_{10}(Ay)_{10} - X \rightarrow -(Ax)$<br>0 - $(EA)_{10} - X \rightarrow EA$ |

#### Befehle zur Kontrolle des Programmflusses

| Befehl | Operation                                                                        |  |
|--------|----------------------------------------------------------------------------------|--|
| Bcc    | Bedingte Verzweigung. Adreßdistanzwert 8 oder 16 Bit.                            |  |
| DBcc   | Test der Bedingung, Dekrementierung und Verzweigung,<br>Adreßdistanzwert 16 Bit. |  |
| Scc    | Test der Bedingung und Setzen des Bytes auf FF oder 00                           |  |
| BRA    | Verzweigung. Adreßdistanzwert 8 oder 16 Bit.                                     |  |
| BSR    | Verzweigung ins Unterprogramm. Adreßdistanzwert 8 oder 16 Bit.                   |  |
| JMP    | Sprung.                                                                          |  |
| JSR    | Sprung ins Unterprogramm                                                         |  |
| RTR    | Rückkehr aus Unterprogramm mit Wiederherstellung des Statusregisters vom Stapel. |  |
| RTS    | Rückkehr aus Unterprogramm.                                                      |  |

#### Systemsteuerbefehle

| Befehl                                                                                   | ,  | Operation                                                                                                                                                                                                                                                                                          |
|------------------------------------------------------------------------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Privilegierte Befehle ANDI to SR EORI to SR ORI to SR MOVE EA to MOVE USP RESET RTE STOP | SR | Logisches UND mit Statusregister. Logisches EXKLUSIV-ODER mit Statusreg ster. Logisches ODER mit Statusregister. Laden des Statusregisters. Datentransport von/nach Benutzerstapelzeiger. Initialisierung der externen Schaltkreise. Rückkehr von einer Ausnahme. Anhalten der Programmausführung. |
| TRAP-Befehle<br>CHK<br>TRAP<br>TRAPV                                                     |    | Register auf Grenzen prüfen.<br>Übergang in den Ausnahmezustand<br>Übergang in den Ausnahmezustand, wenn V = 1.                                                                                                                                                                                    |

Abb. 5.1: Der Befehlssatz, gegliedert nach Typen (Forts.)

#### Systemsteuerbefehle

| Befehl |      |         |      | Operation                                                    |  |  |  |  |
|--------|------|---------|------|--------------------------------------------------------------|--|--|--|--|
| Beding | ungs | codereg | ster |                                                              |  |  |  |  |
| ANDI   | to   | CCR     |      | Logisches UND mit dem Anwender-Statusregister.               |  |  |  |  |
| EORI   | to   | CCR     |      | Logisches EXKLUSIV-ODER mit dem Anwender-<br>Statusregister. |  |  |  |  |
| ORI    | to   | CCR     |      | Logisches ODER mit dem Anwender-Statusregister.              |  |  |  |  |
| MOVE   | EA   | to      | CCR  | Laden des Anwender-Statusregisters.                          |  |  |  |  |
| MOVE   | SR   | to      | EĄ   | Speicherung des Statusregisters.                             |  |  |  |  |

Abb. 5.1: Der Befehlssatz, gegliedert nach Typen (Forts)

Während der Ausarbeitung der kleinen Anwendungsprogramme benötigen wir gewisse Assembleranweisungen oder "Pseudooperationen", die kleinere Verwaltungsaufgaben übernehmen können. Sie definieren Symbole, weisen Adressen für temporäre Speicherung zu, steuern Druckformate etc. Deshalb wollen wir uns diese Anweisungen zuerst anschauen.

#### ORG.S

legt die Anfangsadresse des Objektprogramms absolut kurz fest.

#### ORG.L

legt die Anfangsadresse des Objektprogramms absolut lang fest, d. h. man hat die Möglichkeit, mit 24-Bit-Adressen zu operieren. Wird keine Angabe gemacht, so ist .L standardmäßig festgelegt.

| - |     |     |     |
|---|-----|-----|-----|
| н | CIS | pie | 10. |
| w | C13 | DIM | IV. |

| •                 | 00002000     |      | ORG.L | \$2000  |
|-------------------|--------------|------|-------|---------|
| 00002000          | 4EF900003000 |      | JMP   | ADR1    |
| WARNING 551       |              |      |       |         |
| 00002006          | 4EF900020000 |      | JMP   | ADR2    |
|                   | 00002100     |      | ORG   | \$2100  |
| 00002100          | 4EF900003000 |      | JMP   | ADRI    |
| WARNING 551       |              |      |       |         |
| 00002106          | 4EF900020000 |      | JMP   | ADR2    |
|                   | 00003000     |      | ORG   | \$3000  |
| 00003000          | 4E71         | ADR1 | NOP   |         |
|                   | 00020000     |      | ORG   | \$20000 |
| 00020000          | 4E71         | ADR2 | NOP   | ,       |
|                   |              |      | END   |         |
| <b>TOTAL ERRO</b> | RS           | 0    |       |         |
| TOTAL WARN        | IINGS        | 2    |       |         |

Die beiden Warnungen weisen darauf hin, daß ADRI, das im Bereich ORG.L liegt, eine kurze Adresse ist.

| 00002000<br>WARNING | 00002000<br>4EF900003000 | )   | ORG.L<br>JMP | \$2000<br>ADR1 |
|---------------------|--------------------------|-----|--------------|----------------|
| 00002006            | 4EF900020000             | )   | JMP          | ADR2           |
|                     | 00002100                 |     | ORG.S        | \$2100         |
| 00002100            | 4EF83000                 |     | JMP          | ADR1           |
| 00002104            | 4AFB4E71                 |     | JMP          | ADR2           |
| ERROR 2             | 252                      |     |              |                |
|                     | 00003000                 |     | ORG          | \$3000         |
| 00003000            | 4E71                     | ADR | 1 NOP        | 4              |
|                     | 00020000                 |     | ORG          | \$20000        |
| 00020000            | 4E71                     | ADR | 2 NOP        | +              |
|                     |                          |     | END          |                |
| TOTAL ERF           | RORS                     | 1   |              |                |
| TOTAL WA            | RNINGS                   | 1   |              |                |

Der Fehler (ERROR) wird durch den Befehl JMP ADR2 in dem Bereich von ORG.S verursacht, da die Adresse ADR2 lang ist. Anstelle des Codes für JMP finden wir den Code für den illegalen Befehl 4AFB.

#### RORG

weist den relativen Speicherplatz zu.

#### Beispiel:

RORG \$3000

Das Programm beginnt an der Adresse \$3000, und die relativen Adressierungsarten sind erlaubt.

DC Define Constant

#### DC.B

definiert eine oder mehrere Speicherkonstanten mit Bytelange, die im Speicher an aufeinanderfolgenden Adressen abgelegt werden.

#### Beispiele:

DC.B 'ABCDEF' Die 6 ASCII-Codes der Zeichen A bis F werden im Speicher abgelegt.

# DC.B 'DAS PROGRAMM IST BEENDET.' DC.B \$0A,\$08,\$0B,\$07

#### DC.W

definiert eine oder mehere Speicherkonstanten mit Wortlänge, die im Speicher an aufeinanderfolgenden Adressen abgelegt werden.

#### Beispiele:

NUL DC.W 0 VAL DC 'F' Ablegen der Worte 00, 0F.

#### DC.L

definiert eine oder mehrere Speicherkonstanten mit Doppelwortlänge, die im Speicher an aufeinanderfolgenden Adressen abgelegt werden.

#### Beispiel:

WERT DC.L \$FFFFEE00

DS

DS.B n

reserviert einen Speicherbereich in der Länge von n Bytes.

Beispiel:

TABL DS.B 30 Reservierung von 30 Bytes ab der Adresse TABL.

DS.Wn

reserviert einen Speicherbereich in der Länge von n Worten.

Beispiel:

WERT DS.W 4 Reservierung von 4 Worten ab der Adresse WERT.

#### DS.L n

reserviert einen Speicherbereich in der Länge von n Doppelworten.

#### Beispiel:

ZEIGER DS.L 2 Reservierung von 2 Doppelworten ab der Adresse ZEIGER.

#### **SET**

weist den Symbolen im Programm temporare Werte zu.

#### Beispiel:

INDEX SET INDEX+1

#### **EOU**

setzt den Wert eines Symbols gleich einem anderen bis zu einer maximalen Länge von 32 Bits.

#### Beispiel:

VEKTBERR EQU 2\*4 Die Ausnahmeverarbeitung Bus Error findet ihren Ausnahmevektor an der Adresse 8.

VEKTGL EQU 24\*4

Beispiel zur Verdeutlichung des Unterschieds von SET und EQU:

|                                  | 00002000<br>00000010             |   | VAL1 | ORG<br>EOU               | \$2000<br>\$10 |
|----------------------------------|----------------------------------|---|------|--------------------------|----------------|
| ERROR 234                        |                                  |   |      |                          | 4.0            |
| 00002000<br>00002002<br>00002004 | 0000FFFF<br>4E71<br>4E71<br>4E71 | , | VAL2 | SET<br>NOP<br>NOP<br>NOP | \$FFFF         |
| ERROR 234                        | 00000020                         | ٦ | VAL1 | EQU                      | \$20           |
| 00002006                         | 0000EEEE<br>4E71                 | 1 | VAL2 | SET<br>NOP<br>END        | \$EEEE         |
| TOTAL ERRO<br>TOTAL WARN         |                                  | 2 |      | BND                      |                |

Das Programm ruft zwei Assemblierungsfehler hervor, da der Wert WERT1 zweimal definiert ist, dies bei der Assembleranweisung EQU aber nicht erlaubt ist.

Dieses Problem stellt sich nicht für den Wert WERT2, da dieser durch SET definiert wurde.

#### **END**

ist die Assembleranweisung für das Programmende.

#### MACRO

definiert einen Makrobefehl.

#### Beispiel:

MAKPRO MACRO PROGA, PROGB

#### **ENDM**

zeigt das Ende des Makrobefehls an.

#### IFEQ xx

assembliert, wenn der angegebene Wert xx gleich 0 ist.

#### IFNE xx

assembliert, wenn der angegebene Wert xx gleich 1 ist.

#### **ENDC**

beendet die bedingte Assemblierung.

#### Beispiel:

Im folgenden Programm wird gemäß der Definition von SINN eine Linksoder Rechtsrotation ausgeführt.

| SINN | EQU         | 1 oder 0 |
|------|-------------|----------|
|      | ORG         | \$2000   |
|      | IFEQ        | SINN     |
|      | ROL         | #2, D0   |
|      | <b>ENDC</b> |          |
|      | IFNE        | SINN     |
|      | ROR         | #3, D0   |
|      | <b>ENDC</b> |          |
|      | END         |          |

#### Zum Zeitpunkt der Assemblierung erhält man entweder:

| 00000001 | SINN           | EQU         | 1      |
|----------|----------------|-------------|--------|
| 00002000 |                | ORG         | \$2000 |
|          |                | IFEQ        | SINN   |
|          |                | <b>ENDC</b> |        |
|          |                | IFNE        | SINN   |
| 00002000 | E658           | ROR         | #3, D0 |
|          |                | <b>ENDC</b> |        |
|          |                | END         |        |
| TOTAL E  | RRORS          |             | 0      |
| TOTAL W  | <b>ARNINGS</b> | 5           | 0      |

#### oder:

| 00000000 | SINN    | EQU  | 0      |
|----------|---------|------|--------|
| 00002000 |         | ORG  | \$2000 |
|          |         | IFEQ | SINN   |
| 00002000 | E558    | ROL  | #2, D0 |
|          |         | ENDC |        |
|          |         | IFNE | SINN   |
|          |         | ENDC |        |
|          |         | END  |        |
| TOTALE   | RRORS   |      | 0      |
| TOTAL W  | ARNINGS |      | 0      |
|          |         |      |        |

#### LLEN

bestimmt die Anzahl der Zeichen pro Zeile.

#### Beispiel:

LLEN 120 setzt 120 Zeichen pro Zeile.

#### **PLEN**

bestimmt die Anzahl der Zeilen pro Seite.

#### Beispiel:

PLEN 50 setzt 50 Zeilen pro Seite.

#### NOOBJ

bewirkt keine Ausgabe der Objektdatei.

#### SPC

bewirkt einen Zeilenvorschub.

#### Beispiel:

SPC 10 gibt 10 Zeilen Vorschub.

#### TTL

ermöglicht, eine maximal 60 Zeichen lange Programmüberschrift anzugeben.

#### **BESCHREIBUNG DES BEFEHLSSATZES**

#### Verwendete Abkurzungen:

An - Adreßregister n

D8 - 8-Bit-Adreßdistanzwert

D16 - 16-Bit-Adreßdistanzwert

Dn - Datenregister n
EA - effektive Adresse

PC - Programmzähler

SR - Statusregister

() - Inhalt von

<> - obligatorische Angaben

→ - ergibt

Die Auswirkung der Befehlsausführung auf die Bedingungscodes wird durch folgende Notation angegeben:

- B Bit wird beeinflußt
- U undefiniert
- Bit wird nicht beeinflußt
- 0 Bit wird auf 0 gesetzt
- 1 Bit wird auf 1 gesetzt

Befehle, die mit einem Stern \* gekennzeichnet sind, werden in einem weiteren Abschnitt des Kapitels ausfuhrlich mit Beispielen besprochen.

#### ABCD \* Add Binary Coded Decimal Addiere dezimal mit Frweite Addiere dezimal mit Erweiterungsbit

Operation:

 $(Quelle)_{10}^+(Ziel)_{10}^+X \rightarrow Ziel$ 

Assemblersyntax:

ABCD Dy, Dx

oder

ABCD - (Ay), -(Ax)

Operandenlänge:

Byte

Beschreibung:

Die Addition wird mit binar codierten Dezimalzahlen durchgeführt, die sich entweder in zwei Datenregistern oder in zwei Speicherstellen befinden, wobei dann die Operanden in der Adressierungsart "Adreßregister indirekt mit Predekrementierung" adressiert werden. Dabei werden die im Befehl angegebenen

Adreßregister verwendet.

#### Befehlsformat.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1  | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|----|---|
| 1  | 1  | 0  | 0  |    | Rx |   | 1 | 0 | 0 | 0 | 0 | R/M |   | Ry |   |

#### Bezeichnungen:

R/M=0 - Datenregister

R/M=1 - Adreßregister (Adreßregister indirekt

mit Predekrementierung)

Rx Zielregister Ry - Quellregister

Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | U | В | U | В |

N undefiniert.

Z wird auf 0 gesetzt, wenn das Ergebnis nicht 0 ist. Ist es 0, bleibt Z unverändert.

V undefiniert.

C wird auf 1 gesetzt, wenn ein dezimaler Übertrag angefallen ist, sonst wird es auf 0 zurückgesetzt. X wie C.

Bei mehrfach genauen Operationen ist es erforderlich, Z vor der Befehlsdurchführung auf 1 zu setzen (siehe auch Programm 7 im Kapitel "Anwenderprogramme").

### ADD

#### Add Binary Binare Addition

Operation:

(Quelle)+(Ziel)-Ziel

Assemblersyntax:

ADD <EA>,Dn

oder

ADD Dn, <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Binäre Addition eines Operanden zu dem Inhalt eines Datenregisters, wobei der Zieloperand anschließend mit dem Ergebnis überschrieben wird.

#### Befehlsformat:



#### Bezeichnungen:

Operationsmodus

Byte Wort Doppelwort Operation

000 001 010 (<Dn>)+(<EA>)→<Dn> 100 101 110 (<EA>+(<Dn>)→<EA>

Register - gibt eins der 8 Datenregister an.

Wenn <EA> die Quelle ist, sind folgende Adressierungsarten erlaubt:

| Adressierungsart | Modus | Register             | Adressler⊾ngsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An*              | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers | d(PC, XI)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

<sup>\*</sup> Nur Wort und Doppelwort

### Wenn <EA> das Ziel ist, sind folgende Adressierungsarten gestattet:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     |                      |
| -(An)            | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

#### Bedingungscodes:

| Х | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird bei Überlauf auf 1 gesetzt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein dezimaler Übertrag angefallen ist, sonst auf 0.
- X wie C.

### **ADDA**

### Add Address Addiere Adresse

Operation:

(Quelle)+(Ziel)→Ziel

Assemblersyntax:

ADD <EA>,An

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Binäre Addition eines Operanden zu dem Inhalt

eines Adreßregisters, wobei das Ergebnis im Adreß-

register abgelegt wird.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10    | 9  | 8     | 7       | 6     | 5 | 4     | 3 | 2 | 1     | 0   |
|----|----|----|----|----|-------|----|-------|---------|-------|---|-------|---|---|-------|-----|
| 1  | 1  | 0  | 1  | R  | egist | er | Opera | ationsi | nodus | N | /lodu | s | R | egisl | ter |
|    |    |    |    |    |       |    |       |         |       | _ |       | _ |   | _     |     |

Effektive Adresse

Bezeichnungen:

Register

- gibt eins der 8 Adreßregister

an.

Operationsmodus - 011 - Wortoperation.

Der Quelloperand wird dabei

auf 32 Bits erweitert.

111 – Doppelwortoperation.

<EA> ist immer die Quelle, alle Adressierungsarten sind erlaubt:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Reg ster             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xı)        | 110   | Nummer des Registers |
| An               | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmitteloar      | 111   | 100                  |

Bedingungscodes: unverändert.

### ADDI Add Immediate Addiere unmittelbar

Operation: <unmittelbares Datenelement>+ (Ziel)-Ziel

Assemblersyntax: ADDI #<Datenelement>,<EA>

Operandenlänge: Byte, Wort, Doppelwort

0

Beschreibung: Binäre Addition eines unmittelbaren Datenelemen-

tes zu einem Zieloperanden, wobei der Zieloperand

mit dem Ergebnis überschrieben wird.

Befehlsformat:

14

a 0

Effektive Adresse (<EA>) 13 12 11 10 8 Operations-Modus Register 16-Bit-Datenwert 8-Bit-Datenwert 32-Bit-Datenwert (das vorhergehende Wort ist mit eingeschlossen)

Bezeichnungen:

Operationsmodus - 00 - Byte 01 - Worts 10 - Doppelwort

<EA> ist immer das Ziel. Folgende Addressierungsarten sind erlaubt:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register .           |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     |                      |
| -(An)            | 100   | Nummer des Registers | d(PC, Xı)        | _     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf entsteht, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein Übertrag anfällt, sonst auf 0.
- X wie C.

Wenn die Addition mit einem Adreßregister durchgeführt wird, werden die Bedingungscodes nicht berührt.

### ADDQ Add Quick Addiere schnell

Operation:

<unmittelbares Datenelement>+(Ziel) • Ziel

Assemblersyntax:

ADDQ #<Datenelement>,<EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Binäre Addition eines unmittelbaren Datenelementes zu einem Zieloperanden, wobei der Zieloperand mit dem Ergebnis überschrieben wird. Die Daten können die Werte 0 bis 7 (000 bis 111) annehmen.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10    | 9 | 8 | 7     | 6              | 5 | 4     | 3 | 2 | 1     | 0  |
|----|----|----|----|----|-------|---|---|-------|----------------|---|-------|---|---|-------|----|
| 0  | 1  | 0  | 1  |    | Daten |   | 0 | Opera | itions-<br>dus | I | /lodu | S | R | egisl | er |
|    |    |    |    |    |       |   |   | ,     |                | - |       |   |   |       |    |

Effektive Adresse

Bezeichnungen:

Operationsmodus - 00 - Byte

01 – Wort

10 - Doppelwort

<EA> ist immer das Ziel. Folgende Addressierungsarten sind erlaubt:

| Adress/erungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | ơ(An, Xi)        | 110   | Nummer des Register: |
| An*              | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| -(An)            | 100   | Nummer des Registers | d(PC, Xi)        |       | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     |                      |

<sup>\*</sup> Nur Wort und Doppelwort

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf entsteht, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein Übertrag anfällt, sonst auf 0.
- X wie C.

Wenn die Addition mit einem Adreßregister durchgeführt wird, werden die Bedingungscodes nicht berührt.

### ADDX Add with Extend Addiere mit Erwa

### Addiere mit Erweiterungsbit

Operation:

(Quelle)+(Ziel)+X +Ziel

Assemblersyntax:

ADDX Dy, Dx

oder

ADDX - (Ay), -(Ax)

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung.

Addition des Quell- zu dem Zieloperanden und dem Erweiterungsbit, wobei der Zieloperand mit dem Ergebnis überschrieben wird. Die Operanden sind entweder in Datenregistern oder in Speicherfeldern enthalten.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10          | 9  | 8 | 7           | 6              | 5 | 4 | 3   | 2 | 1           | 0   |
|----|----|----|----|----|-------------|----|---|-------------|----------------|---|---|-----|---|-------------|-----|
| 1  | 1  | 0  | 1  | R  | egist<br>Rx | er | 1 | Opera<br>mo | itions-<br>dus | 0 | 0 | R/M | A | egisl<br>Ry | ler |

#### Bezeichnungen:

R/M=0

Datenregister.

R/M=1- Adreßregister mit Predekrementierung.

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 0 gesetzt, wenn das Ergebnis ungleich 0 ist, sonst auf unverändert.

- V wird auf 1 gesetzt, wenn ein Überlauf entsteht, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein Übertrag anfällt, sonst auf 0.
- X wie C.

Bei Operationen mit mehrfacher Genauigkeit ist es ratsam, vor der Ausführung Z auf 1 zu setzen (siehe auch Programm 7 im Kapitel "Anwenderprogramme").



#### AND Logical Logisches UND

Operation: (Quelle)∧(Ziel)→Ziel

Assemblersyntax: AND <EA>,Dn

oder

AND Dn, <EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung. Der Quelloperand wird mit dem Zieloperanden über

ein logisches UND verknüpft. Dabei darf der Ope-

rand nicht Inhalt eines Adreßregisters sein.

Befehlsformat:

15 14 13 12 11 10 9 8 7 5 4 3 1 Operations-0 Register Modus Register modus

Effektive Adresse

Bezeichnungen:

Register - gibt eins der 8 Datenregister an.

Operationsmodus

Byte Wort Doppelwort Operation

000 001 010 (Dn)UND(<EA>) \*Dn 100 101 110 (<EA>)UND(Dn)

-< EA>

Wenn <EA> die Quelle ist, sind folgende Adressierungsarten erlaubt:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     |                      | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| -(An)            | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

### Wenn <EA> das Ziel ist, sind folgende Adressierungsarten gestattet:

| Adressierungsart | Modus | Reg ster             | Adressierungsart | Modus | Reg ster             |  |  |
|------------------|-------|----------------------|------------------|-------|----------------------|--|--|
| Dn               | _     | - ]                  | d(An, Xi)        | 110   | Nummer des Registers |  |  |
| An               | -     | -                    | Abs W            | 111   | 000                  |  |  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |  |  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |  |  |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | -     | _                    |  |  |
| d(An)            | 101   | Nummer des Registers | unmitte/bar      | _     |                      |  |  |

#### Bedingungscodes:

| X | N | Z | V | C |  |  |
|---|---|---|---|---|--|--|
| - | В | В | 0 | 0 |  |  |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt.
- X unbeeinflußt.

### **ANDI**

#### AND Immediate Logisches UND unmittelbar

Operation: <unmittelbare Daten> \((Ziel) \rightarrow Ziel)

Assemblersyntax: ANDI #<Daten>,<EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung: Die unmittelbaren Daten werden mit dem Zielope-

randen über ein logisches UND verknüpft.





Bezeichnungen:

Operationsmodus - 00 - Byte 01 - Wort 10 - Doppelwort

<EA> ist der Quelloperand, und folgende Adressierungsarten sind erlaubt:

| Adresslerungsart | Modus                                                                                                   | Register             | Adressierungsart   | Modus | Register           |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------|----------------------|--------------------|-------|--------------------|--|--|--|
| On               | 000                                                                                                     | Nummer des Registers | egisters d(An, Xi) |       | Nummer des Registe |  |  |  |
| An               | -                                                                                                       | _                    | Abs.W              | 111   | 000                |  |  |  |
| (An)             | (An)         010         Nummer des Registers           (An) +         011         Nummer des Registers |                      | Abs.L              | 111   | 001                |  |  |  |
| (Ал) +           |                                                                                                         |                      | d(PC)              | -     | -                  |  |  |  |
| (An) 100 Nu      |                                                                                                         | Nummer des Registers | d(PC, Xı)          |       | -                  |  |  |  |
| đ(An)            | d(An) t01 Nummeraes Regis                                                                               |                      | unmittelbar        | T -   |                    |  |  |  |

### Bedingungscodes:

| X | N | Z | V | С |  |  |
|---|---|---|---|---|--|--|
|   | В | В | 0 | 0 |  |  |

- N wird auf 1 gesetzt, wenn das hochstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt.
- X unbeeinflußt

### ANDI mit CCR

AND Immediate to Condition Code Register Logisches UND unmittelbar mit Bedingungscoderegister

Operation:

<unmittelbare Daten> \( (Bedingungscoderegister) )

-- Bedingungscoderegister

Assemblersyntax:

ANDI #<8-Bit-Daten>,CCR

Operandenlänge:

Byte

Beschreibung:

Die unmittelbaren Daten von 8 Bit Länge werden mit dem Bedingungscoderegister über ein logisches UND

verknüpft.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|-----------------|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 0               | 0 | 1 | 1 | 1 | 1 | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 8-Bit-Datenwert |   |   |   |   |   |   | ` |

Bedingungscodes:

Die Bedingungscodes werden entsprechend der logischen Verknüpfung beeinflußt.

#### Beispiel:

Das Bit C wird auf 0 gesetzt, wenn das Bit 0 der unmittelbaren Daten 0 ist; andernfalls bleibt es unverändert. Dasselbe gilt für N, Z, V, X.

## ANDI mit SR

#### AND Immediate to Status Register Logisches UND unmittelbar mit vollem Statusregister

Operation:

Wenn der Prozessor im Supervisor-Modus ist:

<unmittelbare Daten>∧SR→SR

andernfalls Ausnahmeverarbeitung "Privilegverlet-

zung".

Assemblersyntax:

ANDI #<16-Bit-Daten>,SR

Operandenlänge:

Wort

Beschreibung:

Die unmittelbaren Daten von 16 Bit Länge werden mit dem Statusregister SR über ein logisches UND verknüpft, wenn der Prozessor im Supervisor-Modus ist, andernfalls liegt eine Privilegverletzung vor.

#### Befehlsformat:

| 15                             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0                              | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | Q | 0 |
| unmittelbarer 16-Bit-Datenwert |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Bedingungscodes:

Die Bedingungscodes werden entsprechend der logischen Verknüpfung beeinflußt, und zwar nur durch die 5 niederwertigsten Bits der unmittelbaren Daten.

Beispiel:

Das Bit N wird auf 0 gesetzt, wenn das Bit 3 der unmittelbaren Daten 0 ist; andernfalls bleibt es unverändert. Dasselbe gilt für Z, V, C, X.

Arithmetic Shift Left, Right ASL, ASR \* Arithmetische Verschiebung links, rechts

(Ziel) verschoben um<Stellenzahl>→Ziel Operation:

; ASR Dx, Dy Assemblersyntax: ASL Dx, Dy

ASL #<Daten>,Dn; ASR #<Daten>,Dn

ASL <EA> ; ASR <EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung: Die Bits des Operanden werden in der angegebenen

Richtung arithmetisch verschoben. Bei einer Registerverschiebung kann der Verschiebungsfaktor auf

zwei verschiedene Weisen angegeben werden:

- durch einen unmittelbaren Wert (von 1 bis 8)

- durch einen Wert in einem Datenregister

Der Inhalt einer Speicherstelle kann nur um ein Bit verschoben werden, und der Operand muß immer ein

Wort sein.



Befehlsformat: Verschiebung eines Registers

| 15 | 14 | 13 | 12 | 11 | 10            | 9 | 8  | 7     | 6 | 5   | 4 | 3 | 2 | 1     | U  |
|----|----|----|----|----|---------------|---|----|-------|---|-----|---|---|---|-------|----|
| 1  | 1  | 1  | 0  |    | nzah<br>egist |   | dr | Opera |   | l/r | 0 | 0 | R | eg st | er |

#### Bezeichnungen:

Anzahl/Register

- bestimmt die Anzahl der Verschiebungen oder das Register, das diese Zahl enthält.

i/r

- 1/r=0 - die Anzahl der Verschiebungen (von 1 bis 8) ist

im Befehl enthalten.

i/r=1 - die Anzahl der Verschiebungen (modulo 64) ist im angegebenen Register enthalten.

dr

- gibt die Richtung der Ver-

schiebung an.

dr=0 - Verschiebung

nach rechts.

dr=1 - Verschiebung

nach links.

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Register - gibt die Nummer des Datenre-

gisters an, dessen Inhalt ver

schoben werden soll.

#### Befehlsformat: Verschiebung einer Speicherstelle

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5     | 4 | 3 | 2     | 1  | 0 |
|----|----|----|----|----|----|---|----|---|---|-------|---|---|-------|----|---|
| 1  | 1  | i  | 0  | 0  | 0  | 0 | dr | 1 | 1 | Modus |   | R | egist | er |   |
|    |    |    |    |    |    |   |    |   |   | _     |   |   | _     | _  |   |

Effektive Adresse <FA>

#### Bezeichnungen:

dr

- bestimmt die Richtung der Verschiebung.

dr=0 - Verschiebung

nach rechts.

dr=1 - Verschiebung

nach links.

Effektive Adresse - bestimmt den Operanden, der verschoben werden soll.

| Adress erungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     |                      | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| -(An)            | 100   | Nummer des Registers | d(PC, Xi)        |       |                      |
| d(An)            | 101   | Nummer des Registers | unmitte bar      | _     | _                    |

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn das höchstwertige Bit während der Verschiebung verändert wird, sonst auf 0.
- C wird entsprechend dem letzten aus dem Operanden geschobenen Bit gesetzt. Es wird auf 0 gesetzt, wenn keine Verschiebung stattgefunden hat.
- X wird wie C entsprechend dem letzten aus dem Operanden geschobenen Bit gesetzt. Es bleibt unverändert, wenn keine Verschiebung stattgefunden hat.

## Bcc \*

#### Branch Conditionally Bedingte Verzweigung

Operation: Wenn (Bedingung erfüllt) dann PC+D-PC

Assemblersyntax: Bcc <Label>

Operandenlänge: Byte, Wort

Beschreibung: Wenn die angegebene Bedingung erfüllt ist, wird die

Verarbeitung des Programms an der Adresse PC+

Adreßdistanzwert fortgesetzt.

Der Wert von PC ist die Adresse des aktuellen

Befehls plus 2.

Der Adreßdistanzwert enthält die Differenz in Bytes zwischen der Adresse des Bcc-Befehls und dem angegebenen Label. Ist der Distanzwert ein 8-Bit-Wert, dann ist er im Befehl selbst enthalten. Ist er ein 16-Bit-Wert, so sind die 8 Bits des Befehls 0, und der Adreßdistanzwert ist im folgenden Wort enthalten.

Die Bedingungen cc sind im einzelnen:

| 0400 | 00 | 0 0              | 1                      | 0 0                    |
|------|----|------------------|------------------------|------------------------|
| 0100 | CC | Carry Clear      | ke <u>i</u> n Übertrag | C = 0                  |
| 0101 | CS | Carry Set        | Übertrag               | C = 1                  |
| 0111 | EQ | EQual            | gleich                 | Z = 1                  |
| 0110 | NE | Not Equal        | ungleich               | Z = 0                  |
| 1100 | GE | Greater or Equal | größer oder gleich     | $N \oplus V = 0$       |
| 1110 | GT | Greater Than     | größer                 | $Z + (N \oplus V) = 0$ |
| 0010 | HI | High             | größer                 | C + Z = 0              |
|      |    |                  | (ohne Vorzeichen)      |                        |
| 1111 | LE | Less or Equal    | kleiner oder gleich    | Z + (N⊕V) = 1          |
| 0011 | LS | Less or Same     | kleiner oder gleich    | C + Z = 1              |
|      |    |                  | (ohne Vorzeichen)      |                        |
| 1101 | LT | Less Than        | kleiner                | N⊕ V = 1               |
| 1011 | MI | Minus            | negativ                | N = 1                  |
| 1010 | PL | PLus             | positiv                | N=0                    |
| 1000 | VC | oVerflow Clear   | kein Überlauf          | V = 0                  |
| 1001 | VS | oVerflow Set     | Überlauf               | V = 1                  |
| 0000 | T  | True             | wahr                   | 1                      |
| 0001 | F  | False            | falsch                 | 0                      |

### Befehlsformat:



Bedingungscodes: nicht beeinflußt.

# BCHG \* Bit Test and Change Ändern eines Bits nach Test

Operation:

Bit Nummer vom Ziel→Z

Bit-Nummer vom Ziel→logisches Komplement

Assemblersyntax:

BCHG Dn, <EA>

oder

BCHG #<Daten>,<EA>

Operandenlänge:

Byte, Doppelwort

Beschreibung:

Ein Bit des Zieloperanden wird getestet, und sein Wert bestimmt den Bedingungscode Z. Anschlie-Bend wird das Bit komplementiert. Der Zieloperand kann ein Datenregister sein. In diesem Fall wird eins der 32 Bits des Registers getestet. Falls der Zieloperand in einer Speicherstelle steht, so wird eins der 8 Bits des Bytes, das sich an dieser Stelle befindet, getestet. Die Nummer des zu testenden Bits wird entweder unmittelbar oder in einem Datenregister fest-

gelegt.

Befehlsformat:

BCHG Dn, <EA>



Effektive Adresse

Bezeichnungen:

Register (Dn)

ist das Datenregister, das die

Bit-Nummer enthält.

Effektive Adresse – gibt den Zieloperanden an.

| Adressierungsart | Modus | Reg ster             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn*              | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | _     |                      | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| -(An)            | 100   | Nummer des Registers | d(PC Xi)         | -     | _                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

Nur Doppelwort. Bei den anderen Modi nur Byte.

Befehlsformat: BCHG #<Daten>,<EA>



| X | N | Z | V | С |
|---|---|---|---|---|
|   |   | В | _ | - |

- N nicht beeinflußt.
- Z wird auf 1 gesetzt, wenn das getestete Bit 0 ist, sonst auf 0.
- V nicht beeinflußt.
- C nicht beeinflußt.
- X nicht beeinflußt.

# BCLR \* Bit Test and Clear Löschen eines Bits nach Test

Operation: Bit-Nummer xxx des Ziels-Z

0→Bit-Nummer xxx des Ziels

Assemblersyntax: BCLR Dn, <EA>

oder

BCLR #<Daten>,<EA>

Operandenlänge: Byte, Doppelwort

Beschreibung: Ein Bit des Zieloperanden wird getestet, und sein

Wert bestimmt den Bedingungscode Z. Anschlie Bend wird das Bit gelöscht. Der Zieloperand kann ein Datenregister sein. In diesem Fall wird eins der 32 Bits des Registers getestet. Falls der Zieloperand in einer Speicherstelle steht, so wird eins der 8 Bits des Bytes, das sich an dieser Stelle befindet, getestet. Die Nummer des zu testenden Bits wird entweder unmit-

telbar oder in einem Datenregister festgelegt.

Befehlsformat: BCLR Dn, <EA>



Effekive Adresse

Bezeichnungen:

Register – gibt die Nummer des Re-

gisters Dn an, das die Nummer des auf 0 zu setzenden und zu testenden Bits enthält.

Effektive Adresse – bestimmt den Zieloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Ðn"              | 000   | Nummer des Registers | d(An, XI)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | -     |                      |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

<sup>\*</sup> Nur Doppe wort. Bei den anderen Modi nur Byle

| Befehlsformat: |     |    | В  | CLI | R # | <da< th=""><th>aten</th><th>&gt;,&lt;</th><th>EA</th><th>&gt;</th><th></th><th>Effe</th><th>ektive</th><th>. Adr</th><th>esse</th><th></th></da<> | aten | >,< | EA  | >     |               | Effe  | ektive | . Adr | esse |   |
|----------------|-----|----|----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|-----|-------|---------------|-------|--------|-------|------|---|
|                | 15  | 14 | 13 | 12  | 11  | 10                                                                                                                                                | 9    | 8   | 7   | 6     | 5             | 4     | 3      | 2     | 1    | 0 |
|                | 0 0 |    |    | 0   | 1   | 0                                                                                                                                                 | 0    | 0   | 1   | 0     | Modus Registe |       |        | er    |      |   |
|                | 0   | 0  | 0  | 0   | 0   | 0                                                                                                                                                 |      | N   | umm | er de | s Re          | giste | rs     |       |      |   |

#### Bezeichnungen:

Effektive Adresse – bestimmt den Zieloperanden.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adresslerungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn*              | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     |                      |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmillelbar      | -     | -                    |

<sup>\*</sup> Nur Doppelwort. Bei den anderen Modi nur Byte

| X | r<br>k | N | Z | V | C |
|---|--------|---|---|---|---|
| - | -      | - | В | - | _ |

- N nicht beeinflußt.
- Z wird auf 1 gesetzt, wenn das getestete Bit 0 ist, sonst auf 0.
- V nicht beeinflußt.
- C nicht beeinflußt.
- X nicht beeinflußt.



#### Branch Always Unbedingte Verzweigung

Operation:

PC+D→PC

Assemblersyntax:

BRA < Label>

Operandenlänge:

Byte, Wort

Beschreibung:

Der nächste auszuführende Befehl steht an der Adresse PC+Adreßdistanzwert. Der Distanzwert ergibt sich aus der Differenz zwischen dem Wert des PC im Augenblick der Ausführung des Befehls BRA

((PC)+2) und dem angegebenen Label.

Ist der Distanzwert ein 8-Bit-Wert, so ist er im Befehlswort enthalten. Ist er ein 16-Bit-Wert, so ist er im Erweiterungswort enthalten, und die 8 Bits des Befehlswortes sind auf 0 gesetzt. Der Adreßdistanzwert wird immer im Zweierkomplement angegeben.

#### Befehlsformat:



#### oder aber:



Bedingungscodes: nicht beeinslußt.

# BSET \* Bit Test and Set Setze Bit nach Test

Operation:

Bit-Nummer xxx des Ziels→Z

1→Bit-Nummer xxx des Ziels

Assemblersyntax:

BSET Dn, <EA>

oder

BSET #<Daten>,<EA>

Operandenlänge:

Byte, Doppelwort

Beschreibung:

Ein Bit des Zieloperanden wird getestet, und sein Wert bestimmt den Bedingungscode Z. Danach wird dieses Bit im Zieloperanden auf 1 gesetzt. Das Ziel kann ein Datenregister sein, dabei ist das zu testende Bit eins der 32 Bits des Registers. Wenn das Ziel eine Speicherstelle ist, ist das zu testende Bit eins der 8 Bits des Bytes, das sich an dieser Stelle befindet. Die Bitnummer ist entweder unmittelbar angegeben

oder in einem Datenregister enthalten.

Befehlsformat:

BSET Dn, <EA>

| 15 | 14 | 13 | 12 | 11       | 10 | 9 | 8 | 7 | 6 | 5             | 4 | 3        | 2 | 1 | 0 |
|----|----|----|----|----------|----|---|---|---|---|---------------|---|----------|---|---|---|
| 0  | 0  | 0  | 0  | Register |    | 1 | 1 | 1 | I | <b>/lo</b> du | s | Register |   |   |   |
|    |    |    |    |          |    |   |   |   |   |               |   |          | _ |   |   |

Effektive Adresse

Bezeichnungen:

Register

 bezeichnet das Datenregister, das die Bit-Nummer angibt.

Effektive Adresse - legt den Zieloperanden fest.

| Adressierungsart | Modus | Register               | Adressierungsart | Modus | Register             |
|------------------|-------|------------------------|------------------|-------|----------------------|
| Dn*              | 000   | Nummer des Registers   | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | _                      | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers   | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers ! | d(PC)            | -     |                      |
| - (An)           | 100   | Nummer des Registers   | d(PC Xi)         |       |                      |
| d(An)            | 101   | Nummer des Registers   | unmittelbar      | -     | -                    |

<sup>\*</sup> Nur Doppelwort. Bei den anderen Modi nur Byte

| Befehlsfo | rma | t: | В  | BSET # <daten>,<ea></ea></daten> |    |   |   |   |                 |   | Effektive Adresse |   |   |   |    |
|-----------|-----|----|----|----------------------------------|----|---|---|---|-----------------|---|-------------------|---|---|---|----|
|           | 14  | 13 | 12 | 11                               | 10 | 9 | 8 | 7 | 6               | 5 | 4                 | 3 | 2 | 1 | 0  |
|           | 0   | 0  | 0  | 0                                | 1  | 0 | 0 | 0 | 1               | 1 | Modus Register    |   |   |   | er |
|           | 0   | 0  | 0  | 0                                | 0  | 0 | 0 | 0 | Nummer des Bits |   |                   |   |   |   |    |

Bezeichnungen:

Effektive Adresse - legt den Zieloperanden fest.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register            |
|------------------|-------|----------------------|------------------|-------|---------------------|
| Dn*              | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Register |
| An               | -     |                      | Abs.W            | 111   | 000                 |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                 |
| (An) +           | 011   | Nummer des Reg sters | d(PC)            | _     |                     |
| - (An)           | 100   | Nummer des Registers | d(PC Xi)         | -     | -                   |
| d(An)            | 101   | Nummer des Registers | unmitte!bar      |       | *                   |

<sup>&#</sup>x27; Nur Doppelworf. Bei den anderen Modi nur Byte

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | - | В | - | - |

- N nicht beeinflußt
- Z wird auf 1 gesetzt, wenn das getestete Bit 0 ist, sonst auf 0.
- V nicht beeinflußt.
- C nicht beeinflußt.
- X nicht beeinflußt.

## **BSR**

#### Branch to Subroutine

Verzweigung zum Unterprogramm

Operation:

 $PC \rightarrow -(SP)$ 

PC+D→PC

Assemblersyntax:

BSR < Label>

Operandenlänge:

Byte, Wort

Beschreibung:

Die 32-Bit-Adresse des Befehls, die auf den Befehl BSR folgt, wird auf den Stapel gerettet. Das Programm wird an der Adresse (PC)+Adreßdistanzwert weiter ausgeführt. Die Distanz stellt den relativen Abstand zwischen dem Wert des Programmzählers und dem Label dar. Dieser Distanzwert wird durch Bildung des ganzzahligen Zweierkomplements ermittelt und entweder als 8- oder 16-Bit-Zahl angegeben.

#### Befehlsformat:

| 15 | 14                                                             | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5     | 4    | 3     | 2    | 1   | 0 |
|----|----------------------------------------------------------------|----|----|----|----|---|---|---|----|-------|------|-------|------|-----|---|
| 0  | 1                                                              | 1  | 0  | 0  | 0  | 0 | 1 |   | 8- | Bit-A | dreß | dista | ınzw | ert |   |
|    | 16-Bit-Adreßd stanzwert (wenn 8-Bit-Adreßdistanzwert Null ist) |    |    |    |    |   |   |   |    |       |      |       |      |     |   |

Bedingungscodes: nicht beeinflußt.

BTST \* Bit Test
Teste Bit

Operation:

Bit Nummer xxx des Ziels-Z

Assemblersyntax:

BTST Dn, <EA>

oder

BTST #<Daten>,<EA>

Operandenlänge:

Byte, Doppelwort

Beschreibung:

Ein Bit des Zieloperanden wird getestet, und sein Wert bestimmt das Bit Z. Das Ziel kann ein Datenregister sein, dabei ist das zu testende Bit eins der 32 Bits des Registers. Wenn das Ziel eine Speicherstelle ist, ist das zu testende Bit eins der 8 Bits des Bytes, das sich an dieser Stelle befindet. Die Bit-Nummer ist entweder unmittelbar angegeben oder in

einem Datenregister enthalten.

Befehlsformat:

BTST Dn, <EA>



Effektive Adresse

Bezeichnungen:

Register

- gibt das Datenregister an, das

die Bit-Nummer enthält.

Effektive Adresse – legt den Zieloperanden fest.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn*              | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | -                | 111   | -                    |
| - (An)           | 100   | Nummer des Registers | _                | 111   | -                    |
| d(An)            | 101   | Nummer des Registers | -                | 111   | -                    |

<sup>\*</sup> Nur Doppelwort. Bei den anderen Modi nur Byte

| Befehlsformat: BTST # <daten>,<ea></ea></daten> |    |    |    |    |    |    |   |   |   | Effe | ktive          | Adre | sse |      |    |   |
|-------------------------------------------------|----|----|----|----|----|----|---|---|---|------|----------------|------|-----|------|----|---|
|                                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 |   | 7 | 6    | 5              | 4    | 3   | 2    | 1  | 0 |
| •                                               | 0  | 0  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 0    | Modus Register |      |     |      | er |   |
|                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |      | Nur            | nme  | des | Bits |    |   |

Bezeichnungen:

Effektive Adresse - legt den Zieloperanden fest.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn°              | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | _     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            |       |                      |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

<sup>\*</sup> Nur Doppelwort. Bei den anderen Mod nur Byte.

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | _ | В | : | - |

- N nicht beeinflußt.
- Z wird auf 1 gesetzt, wenn das getestete Bit 0 ist, sonst auf 0.
- V nicht beeinflußt.
- C nicht beeinflußt.
- X nicht beeinflußt.

# CHK \* Check Registers Against Bounds Prüfe Register auf Grenzen

Operation:

Wenn Dn<0 oder Dn>(<EA>), dann TRAP, sonst

nächster Befehl

Assemblersyntax:

CHK <EA>,Dn

Operandenlänge:

Wort

Beschreibung:

Die 16 niederwertigen Bits des angegebenen Daten registers werden mit der oberen Grenze (behandelt als Zweierkomplement) des mit der effektiven Adresse angesprochenen Operanden verglichen. Wenn der Wert des Registers kleiner als 0 oder größer als diese obere Grenze ist, dann geht der Prozessor in den Ausnahmezustand CHK, und es wird die

Vektornummer 6 erzeugt

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 10  | 9  | 8 | 7 | 6 | 5 | 4     | 3 | 2 | 1     | 0   |
|----|----|----|----|--------|----|---|---|---|---|-------|---|---|-------|-----|
| 0  | 1  | 0  | 0  | Regist | er | 1 | 1 | 0 | ٨ | /lodu | 5 | R | egist | :er |
|    |    |    |    |        |    |   |   |   | _ |       | _ | _ |       |     |

Effektive Adresse

Bezeichnungen:

Register

- gibt das Datenregister an, dessen Inhalt verglichen wird.

Effektive Adresse – gibt die obere Grenze an. Die folgenden Adressierungsarten sind zulässig:

| Adressierungsarl | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xı)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmitte bar      | 111   | 100                  |

| X | N | Z | V | С |
|---|---|---|---|---|
| 1 | В | U | U | U |

- N wird auf 1 gesetzt, wenn Dn kleiner als 0 ist. Es wird auf 0 gestzt, wenn Dn größer ist als (<EA>), ansonsten ist es undefiniert.
- Z undefiniert.
- V undefiniert.
- C undefiniert.
- X nicht beeinflußt.

### CLR

#### Clear Operand Setze Operand auf 0

Operation:

0→Ziel

Assemblersyntax.

CLR <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Alle Bits des Zieloperanden werden auf 0 gesetzt.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6             | 5 | 4     | 3 | 2 | 1     | 0  |
|----|----|----|----|----|----|---|---|-------------|---------------|---|-------|---|---|-------|----|
| 0  | 1  | 0  | 0  | 0  | 0  | 1 | 0 | Opera<br>mo | tions-<br>dus | N | /lodu | s | B | egist | er |
|    |    |    |    |    |    |   |   |             |               | - |       |   |   |       | _  |

Effektive Adresse

Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Datenwort

Effektive Adresse - legt den Zieloperanden fest.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xı)        | 110   | Nummer des Registers |
| An               | -00-  | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| - (An)           | 100   | Nummer des Registers | d(PC,Xi)         | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

| X | N | Z | V | С |
|---|---|---|---|---|
| - | 0 | 1 | 0 | 0 |

N wird auf 0 gesetzt
Z wird auf 1 gesetzt.
V wird auf 0 gesetzt.
C wird auf 0 gesetzt.
X nicht beeinflußt.



Compare Vergleiche

Operation:

(<Dn>)-(<EA>)

(Ziel)-(Quelle)

Assemblersyntax:

CMP < EA > Dn

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Der Quelloperand wird dem Zieloperanden subtrahiert. Die Bedingungscodes werden dem Ergebnis entsprechend gesetzt. Der Zieloperand bleibt unver-

ändert.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8     | 7      | 6     | 5 | 4     | 3 | 2 | 1     | 0    |
|----|----|----|----|----|--------|----|-------|--------|-------|---|-------|---|---|-------|------|
| 1  | 0  | 1  | 1  | R  | egisti | er | Opera | ations | nodus | N | /lodu | S | R | egist | er . |
| -  |    |    |    |    |        |    |       |        |       |   |       | _ |   | _     |      |

Bezeichnungen:

Register - gibt das Ziel-Datenregister

an.

Operationsmodus - 000 - Byte

001 - Wort

010 - Doppelwort

Effekt ve Adresse

Effektive Adresse - bestimmt den Quelloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An Xi)         | 110   | Nummer des Registers |
| An*              | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Absi             | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

<sup>\*</sup> Nur Wort und Doppelwort

| X | N | Z | V | С |
|---|---|---|---|---|
| - | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 1 gesetzt, wenn es einen Übertrag gibt, sonst auf 0.
- X nicht beeinflußt.

# CMPA Compare Address Vergleiche Adresse

Operation:

 $(\langle An \rangle) - (\langle EA \rangle)$ 

(Ziel)-(Quelle)

Assemblersyntax:

CMPA <EA>,An

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Der Quelloperand wird dem Zieloperanden subtrahiert. Die Bedingungscodes werden dem Ergebnis entsprechend gesetzt. Das Register An bleibt unver andert. Bei einer Wortoperation wird der Quellope-

rand auf 32 Bits erweitert.

#### Befehlsformat:



Effektive Adresse

Bezeichnungen:

Register

gibt das Ziel-Adreßregister

an.

Operationsmodus - 011 - Wortoperation

mit Erweiterung des Quell-

operanden)

111 – Doppelwortoperation

Effektive Adresse

bestimmt den Quell-

operanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)             | 100   | Nummer des Registers | d(PC. XI)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 1 gesetzt, wenn es einen Übertrag gibt, sonst auf 0.
- X nicht beeinflußt.

#### Compare Immediate Vergleiche unmittelbar

Operation:

(<An>)-(<unmittelbare Daten>)

(Ziel)-(Quelle)

Assemblersyntax:

CMPA #<Daten>,<EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung:

Das unmittelbare Datenelement wird vom Zieloperanden subtrahiert. Die Bedingungscodes werden dem Ergebnis entsprechend gesetzt Der Zieloperand bleibt unverändert. Die Länge des unmittelbaren Datenelements stimmt mit der Angabe im Daten-

längencode überein.

#### Befehlsformat:



Bezeichnungen:

Operationsmodus - 00

01 — Wort

10 - Doppelwort

Effektive Adresse – bestimmt den Zieloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| Αп               | _     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | 444-                 |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       |                      |

| X | N | Z | V | С |
|---|---|---|---|---|
|   | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 1 gesetzt, wenn es einen Übertrag gibt, sonst auf 0.
- X nicht beeinflußt.

## **CMPM**

#### Compare Memory Vergleiche Speicher

Operation:

(Ziel)-(Quelle)

Assemblersyntax:

CMPM(Ay)+,(Ax)+

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Der Quelloperand wird vom Zieloperanden subtrahiert. Die Bedingungscodes werden dem Ergebnis entsprechend gesetzt. Die Operanden werden durch Postinkrementierung unter Zuhilfenahme der

Adreßregister angesprochen.

Befehlsformat.

| 15 | 14 | 13 | 12 | 11 | 10          | 9  | 8 | 7     | 6 | 5 | 4 | 3 | 2 | 1           | 0  |
|----|----|----|----|----|-------------|----|---|-------|---|---|---|---|---|-------------|----|
| 1  | 0  | 1  | 1  | R  | egist<br>Ax | er | 1 | Opera |   | 0 | 0 | 1 | R | egist<br>Ay | 61 |

Bezeichnungen:

Register Ax

- bestimmt den Zieloperanden

(für die Postinkremen-

tierung).

Register Ay

bestimmt den Quell-

operanden.

Operationsmodus -00 - Byte

00 - Byte 01 - Wort

10 - Doppelwort

Bedingungscodes:

| 2 | K | N | Z | V | С |
|---|---|---|---|---|---|
| Ŀ | _ | В | В | В | В |

N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.

- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 1 gesetzt, wenn es einen Übertrag gibt, sonst auf 0.
- X nicht beeinflußt.

### **DBcc**

Test, Decrement and Branch Prüfe, dekrementiere und verzweige

Operation:

Wenn die Bedingung nicht erfüllt ist, dann:

 $Dn 1 \rightarrow Dn$ 

Wenn  $Dn \neq -1$ , dann (PC)+D $\rightarrow$ PC,

sonst (PC)+2 -PC

Wenn die Bedingung erfüllt ist, dann keine Opera-

tion

Assemblersyntax.

DBcc Dn.<Label>

Operandenlänge:

Wort

Beschreibung:

Dieser Befehl hat 3 Parameter: eine Bedingung, ein Datenregister und einen Adreßdistanzwert. Er kann für die İmplementierung von Schleifen verwendet werden. Dabei wird die Bedingung cc getestet. Wenn die Abbruchbedingung co nicht erfüllt ist, werden die unteren 16 Bits des Registers Dn um 1 vermindert. Wenn dabei -1 herauskommt, wird der nächstfolgende Befehl ausgeführt. Wenn das Ergebnis ungleich - 1 ist, wird die Programmausführung an der durch den Wert des PC und den Adreßdistanzwert (erweitert) festgelegten Stelle fortgesetzt Die Bedin-

gungen cc können die folgenden sein:

| 0100<br>0101<br>0111<br>0110<br>1100<br>1110<br>0010 | CC<br>CS<br>EQ<br>NE<br>GE<br>GT<br>HI | Carry Clear<br>Carry Set<br>EQual<br>Not Equal<br>Greater or Equal<br>Greater Than<br>High | kein Übertrag Übertrag gleich ungleich größer oder gleich größer größer (ohne Vorzeichen) | $C = 0$ $C = 1$ $Z = 1$ $Z = 0$ $N \oplus V = 0$ $Z + (N \oplus V) - 0$ $C + Z = 0$ |
|------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| 0011                                                 | LS                                     | Less or Equal<br>Less or Same                                                              | kleiner oder gleich                                                                       | 2 + (N⊕V) − 1                                                                       |
|                                                      |                                        |                                                                                            | kleiner oder gleich<br>(ohne Vorzeichen)                                                  | C + Ž - 1                                                                           |
| 1101                                                 | LT                                     | Less Than                                                                                  | k-einer                                                                                   | N(+)V - 1                                                                           |
| 1011                                                 | MI                                     | Minus                                                                                      | negativ                                                                                   | N = 1                                                                               |
| 1010                                                 | PL                                     | Plus                                                                                       | positiv                                                                                   | N-0                                                                                 |
| 1000                                                 | VC                                     | oVerflow Clear                                                                             | kein Überlauf                                                                             | V = 0                                                                               |
| 1001                                                 | VS                                     | oVerflow Set                                                                               | Überlauf                                                                                  | V = 1                                                                               |
| 0000                                                 | T                                      | True                                                                                       | wahr                                                                                      | 1                                                                                   |
| 0001                                                 | F                                      | False                                                                                      | falsch                                                                                    | 0                                                                                   |

#### Befehlsformat:

| 15 | 14               | 13 | 12 | 11 | 10        | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0  |
|----|------------------|----|----|----|-----------|---|---|---|---|---|---|---|---|-------|----|
| 0  | 1                | 0  | 1  | E  | Bedingung |   |   | 1 | 1 | 0 | 0 | 1 | R | egist | er |
|    | Adreßdistanzwert |    |    |    |           |   |   |   |   |   |   |   |   |       |    |

Bezeichnungen:

Bedingung

- enthält eine der 16 in der Tabelle angegebenen Bedingungen.

Register

- gibt das Datenregiser an, das als Zähler verwendet wird.

Adreßdistanzwert - gibt den Abstand zwischen dem ausgeführten Befehl und dem angesprochenen Label an.

Bedingungscodes: unbeeinflußt.

# DIVS \* Signed Divide Division mit Vorzeichen

Operation:

(Ziel)/(Quelle)→Ziel

Assemblersyntax:

DIVS < EA>, Dn

Operandenlänge:

Wort

Beschreibung:

Der 32-Bit-Zieloperand wird durch den 16-Bit-Quelloperanden dividiert. Die Operation wird entsprechend der arithmetischen Vorzeichen durchgeführt. Das 32-Bit-Ergebnis wird folgendermaßen abgespeichert: der Quotient im unteren Wort, der Rest im oberen Teil des Wortes. Das Vorzeichen des Restes entspricht dem des Dividenden, außer wenn er 0 ist. Zwei Sonderfalle können vorkommen: Bei Division durch 0 wird ein Ausnahmezustand ausgelöst (Vektor 5). Ein Überlauf wird vor dem Ende der Befehlsausführung entdeckt, und der entsprechende Bedingungscode wird gesetzt. In diesem Fall werden die Operanden nicht verändert. Es entsteht ein Überlauf, wenn der Quotient einschließlich Vorzeichen

größer als 16 Bit ist.

#### Befehlsformat:



#### Bezeichnungen:

Register

gibt das Datenregister an, das den Zieloperanden enthält.

Effektive Adresse – gibt den Quelloperanden an.

Die zugelassenen Adressierungsarten sind die folgenden:

| Adressierungsart | Modus | Register             | Adressierungsart       | Modus | Register           |  |
|------------------|-------|----------------------|------------------------|-------|--------------------|--|
| Dn               | 000   | Nummer des Registers | d(An, Xi)              | 110   | Nummer des Registe |  |
| An               | _     | _                    | Abs.W                  | 111   | 000                |  |
| (An)             | 010   | Nummer des Registers | Abs L                  | 111   | 001                |  |
| (An) +           | 011   | Nummer des Registers | d(PC)                  | 111   | 010                |  |
| - (An)           | 100   | Nummer des Registers | d(PC, X <sub>1</sub> ) | 111   | 011                |  |
| d(An)            | 101   | Nummer des Registers | unmittelbar            | 111   | 100                |  |

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | В | В | В | 0 |

- N wird auf 1 gesetzt, wenn der Quotient negativ ist, sonst auf 0. Es ist undefiniert, wenn V=1 ist.
- Z wird auf 1 gesetzt, wenn der Quotient 0 ist, sonst auf 0. Es ist undefiniert, wenn V=1 ist.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 0 gesetzt.
- X nicht beeinflußt.

# DIVU \* Unsigned Divide Division ohne Vorzeichen

Operation:

(Ziel)/(Quelle)→Ziel

Assemblersyntax:

DIVU <EA>,Dn

Operandenlänge:

Wort

Beschreibung:

Die Division erfolgt ohne Vorzeichen. Sonst sind die Merkmale dieses Befehls dieselben wie die von DIVS. Man muß nur beachten, daß das Bedingungscodebit N auf 1 gesetzt wird, wenn das höchstwertige Bit des Quotienten gesetzt ist, andernfalls wird N auf 0 gesetzt. Wenn ein Überlauf auftritt und V also 1 wird, ist N undefiniert. Ein Überlauf tritt dann auf, wenn der Quotient ohne Vorzeichen größer als 16 Bits wird.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6 | 5 | 4     | 3 | 2        | 1 | 0  |
|----|----|----|----|----|----------|---|---|---|---|---|-------|---|----------|---|----|
| 1  | 0  | 0  | 0  | R  | Register |   | 0 | 1 | 1 | A | Modus |   | Reg ster |   | er |
|    |    |    |    |    |          |   |   |   |   |   |       |   |          |   |    |

Bezeichnungen:

Effektive Adresse

Register

 gibt das Datenregister an, das den Zieloperanden enthält.

Effektive Adresse – gibt den Quelloperanden an.

Die zugelassenen Adressierungsarten sind die folgenden:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register            |  |
|------------------|-------|----------------------|------------------|-------|---------------------|--|
| Dπ               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Register |  |
| An               | -     | _                    | Abs.W            | 111   | 000                 |  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                 |  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                 |  |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                 |  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                 |  |

| X | N | Z | V | С |
|---|---|---|---|---|
| _ | В | В | В | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Quotienten 1 ist, sonst auf 0. Es ist undefiniert, wenn V−1 ist.
- Z wird auf 1 gesetzt, wenn der Quotient 0 ist, sonst auf 0. Es ist undefiniert, wenn V=1 ist.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 0 gesetzt.
- X nicht beeinflußt.

# **EOR**

#### Exclusive OR Logical Logisches exclusives ODER

Operation:

(Quelle)¥(Ziel)→Ziel

Assemblersyntax:

EOR Dn,<EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Der Quelloperand wird mit dem Zieloperanden über ein logisches exklusives ODER verknüpft, und das Ergebnis wird in den Zieloperanden geschrieben.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10    | 9  | 8     | 7       | 6     | 5 | 4    | 3     | 2    | 1     | 0  |
|----|----|----|----|----|-------|----|-------|---------|-------|---|------|-------|------|-------|----|
| 1  | 0  | 1  | 1  | R  | egist | er | Opera | ationsr | nodus | ħ | Aodu | s     | R    | egist | er |
|    |    |    |    |    |       |    |       |         |       | _ |      |       |      | _     |    |
|    |    |    |    |    |       |    |       |         |       |   | Effe | ktive | Adre | sse   |    |

#### Bezeichnungen:

Register

- gibt das Datenregister an,

(Quelloperand).

Operationsmodus - 100 - Byte

100 – Byte 101 – Wort

110 - Doppelwort

Effektive Adresse – gibt den Zieloperanden an.

Die zugelassenen Adressierungsarten sind die folgenden:

| Adressierungsart | Modus | Reg ster             | Adressierungsart | Modus | Register            |
|------------------|-------|----------------------|------------------|-------|---------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Register |
| An               |       |                      | Abs W            | 111   | 000                 |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                 |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                   |
| - (An)           | 100   | Nummer des Registers | đ(PC, Xi)        | -     | -                   |
| d(An)            | 101   | Nummer des Registers | unm (telbar      | _     |                     |

| X | N | Z | V | С |
|---|---|---|---|---|
|   | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 0 gesetzt.
- C wird auf 0 gesetzt. X nicht beeinflußt.

## **EORI**

#### Exclusive OR Immediate Exklusives ODER unmittelbar

Operation:

<unmittelbare Daten>V(Ziel) \*Ziel

Assemblersyntax: EORI #<Daten>,<EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung.

Das unmittelbare Datenelement wird mit dem Zieloperanden über ein exklusives ODER verknüpft. Die Länge des unmittelbaren Datenelements entspricht

Effektive Adresse

dem angegebenen Datenlängencode.

#### Befehlsformat:



Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - gibt den Zieloperanden an.

Die zugelassenen Adressierungsarten sind die folgenden:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | _     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

#### Bedingungscodes:

|   | X | N | Z | V | С |
|---|---|---|---|---|---|
| i |   | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird auf 0 gesetzt. C wird auf 0 gesetzt. X nicht beeinflußt.

# EORI mit CCR

mit CCR Exclusive OR Immediate to CCR Exklusives ODER unmittelbar mit CCR

Operation:

<unmittelbare Daten>VCCR-CCR

Assemblersyntax:

EORI #<8-Bit-Daten>,CCR

Operandenlänge:

Byte

Beschreibung:

Das unmittelbare 8-Bit-Datenelement wird mit dem unteren Byte des Statusregisters SR über ein exklusi-

ves ODEŘ verknüpft.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4     | 3     | 2    | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|-----|-------|-------|------|---|---|
| 0  | 0  | 0  | 0  | 1  | 0  | 1 | 0 | 0 | 0 | 1   | 1     | 1     | 1    | 0 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   | 8-B | ıl-Da | itenv | ert/ |   |   |

Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

Alle Bedingungscodes werden entsprechend der logischen Verknüpfung beeinflußt.

Beispiel: X wird gesetzt, wenn das Bit 4 des Datenelements 1 ist und X vorher 0 war

## EXClusive OR Immediate to SR Exclusives ODER unmittelbar mit SR

Operation:

Im Supervisor-Modus:

<unmittelbare Daten>VSR +SR

Sonst Ausnahmezustand "Privilegverletzung" (Vek

tor 8).

Assemblersyntax:

EORI #<16-Bit-Daten>,SR

Operandenlänge:

Wort

Beschreibung:

Wenn der Prozessor im Supervisor-Modus ist, wird das unmitelbare 16-Bit-Datenelement mit dem Statusregister SR über ein exklusives ODER verknüpft. Andernfalls wird der Ausnahmezustand "Privilegverletzung" hervorgerufen.

#### Befehlsformat:

| 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0                | 0  | 0  | 0  | 1  | 0  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
| 16-Bit-Datenwert |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

Alle Bedingungscodes werden entsprechend der logischen Verknüpfung beeinflußt.

Beispiel: N wird gesetzt, wenn das Bit 3 des Datenelements 1 ist und N vorher 0 war

### **EXG**

### Exchange Registers Datenaustausch zwischen Registern

Operation:

Rx - Ry

Assemblersyntax:

EXG Rx,Ry

Operandenlänge:

Doppelwort

Beschreibung:

Die 32-Bit-Inhalte von zwei Registern werden miteinander vertauscht. Dieser Austausch kann stattfinden

zwischen:

DatenregisternAdreßregistern

- einem Daten- und einem Adreßregister

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10           | 9  | 8 | 7 | 6    | 5     | 4   | 3  | 2 | 1           | 0  |
|----|----|----|----|----|--------------|----|---|---|------|-------|-----|----|---|-------------|----|
| 1  | 1  | 0  | 0  | R  | egiste<br>Rx | er | 1 | 0 | pera | tions | mod | JS | R | egisi<br>Ry | er |

Bezeichnungen:

Register Rx

 gibt das Daten- oder Adreßregister an. Im Fall des Daten-/Adreßregisteraustauschs gibt es das Datenregister an.

Operationsmodus

- 01000 - Datenregister
 01001 - Adreßregister
 10001 - Daten- und Adreßregister

Register Ry

gibt das Daten- oder Adreßregister an. Im Fall des Daten-/Adreßregisteraustauschs gibt es das Adreßregister an.

## EXT \* Sign Extend Vorzeichenerweiterung

Operation:

(Ziel)vorzeichenerweitert-Ziel

Assemblersyntax:

EXT Dn

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Wortoperation

- Bit 7 wird in die Bits 8 bis 15

kopiert.

Doppelwortoperation

- Bit 15 wird in die Bits 16 bis 31

kopiert.

#### Befehlsformat:

| 15 |   |   | 12 |   |   | - | -  |        | -        | _ | 4 | 3 | 2 | 1     | 0  |
|----|---|---|----|---|---|---|----|--------|----------|---|---|---|---|-------|----|
| 0  | 1 | 0 | 0  | 1 | 0 | 0 | Ор | erat o | ns-<br>S | 0 | 0 | 0 | R | egist | er |

#### Bezeichnungen:

Operationsmodus - 010 - Erweiterung von Byte-

Wortlange. 011 - Erweiterung von Wort-

Register

auf Doppelwortlänge. - gibt das Datenregister an, des-

sen Inhalt erweitert wird.

Bedingungscodes:

| Х | N | Z | V | С |
|---|---|---|---|---|
| _ | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0
- V wird auf 0 gesetzt.
- C wird auf 0 gesetzt.
- X nicht beeinflußt.

### ILLEGAL

#### Illegal Instruction Unzulässiger Befehl

Operation:

 $(PC) \rightarrow -(SSP); (SR) \rightarrow -(SSP)$ 

(Vektor 4)→PC

Assemblersyntax: -

Operandenlänge: nicht definiert.

Beschreibung:

Der Befehl, der den Hexadezimalcode \$4AFC

besitzt, erzeugt die Ausnahmebedingung "illegale Operation", der den Ausnahmevektor 4 hat.

Befehlsformat:

durch die Beschreibung festgelegt.

**JMP** 

Jump Sprung

Operation:

Ziel-PC

Assemblersyntax:

JMP <EA>

Operandenlänge: -

Beschreibung:

Die Ausführung des Programms wird an der im

Befehl angegebenen Adresse fortgesetzt.

Befehlsformat:



Effektive Adresse

Bezeichnungen:

Effektive Adresse – bestimmt die Adresse des nächsten auszuführenden Befehls.

#### Folgende Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Reg ster             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | _     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               | _     | -                    | Abs W            | £15   | 000                  |
| (An)             | 010   | Nummer das Registers | Abs.L.           | 111   | 001                  |
| (An) ÷           | _     | -                    | d(PC)            | 111   | 010                  |
| - (An)           | -     | -                    | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | pro.                 |

### **JSR**

#### Jump to Subroutine Sprung zum Unterprogramm

Operation:

PC→-(SP); Ziel→PC

Assemblersyntax:

JSR <EA>

Operandenlänge. -

Beschreibung:

Die Adresse des unmittelbar auf JSR folgenden Befehls wird auf den Stapel gerettet. Danach wird die Ausführung des Programms an der durch JSR festge-

legten Adresse fortgesetzt.

#### Befehlsformat:



Effektive Adresse

Bezeichnungen:

Effektive Adresse

bestimmt die Adresse des nächsten auszuführenden Befehls

### Folgende Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| On               | -     |                      | d(An, X.)        | 110   | Nummer des Registers |
| An               |       | - :                  | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | -     | -                    | d(PC)            | 111   | 010                  |
| - (An)           | -     | -                    | d(PC, X)         | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmillelbar      | _     |                      |

LEA \* Load effective Address

Laden der effektiven Adresse

Operation:

Ziel→An

Assemblersyntax: LEA <EA>,An

Operandenlänge:

Doppelwort

Beschreibung:

Die effektive Adresse wird in das angegebene Adreß-

register geladen. Alle 32 Bits dieses Registers sind

davon betroffen.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8 | 7 | 6 | 5 | 4     | 3      | 2    | 1     | 0  |
|----|----|----|----|----|--------|----|---|---|---|---|-------|--------|------|-------|----|
| 0  | 1  | 0  | 0  | R  | egisti | er | 1 | 1 | 1 | N | /lodu | S      | R    | egist | er |
|    |    |    |    |    |        |    |   |   |   |   | F #4- | letore |      |       |    |
|    |    |    |    |    |        |    |   |   |   |   | FILE  | KUVE   | Adre | esse  |    |

Bezeichnungen:

Register

- legt das Adreßregister fest, in das die effektive Adresse ge-

laden wird.

Effektive Adresse - bestimmt die zu ladende

Adresse.

### Folgende Adressierungsarten sind zulässig:

| Adresslerungsart | Modus | Register             | Adresslerungsart | Modus | Reg ster             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               |       | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       |                      | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | -     | -                    | d(PC)            | 111   | 010                  |
| - (An)           |       |                      | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       | _                    |

### LINK \*

#### Link and Allocate Verbinden und Speicher reservieren

Operation:

 $An \rightarrow -(SP)$ ;  $SP \rightarrow An$ ;  $SP + D \rightarrow SP$ 

Assemblersyntax.

LINK An, #<16-Bit-Adreßdistanzwert>

Operandenlänge:

Beschreibung:

Der Inhalt des angegebenen Adreßregisters wird auf den Stapel gerettet. Danach wird der Inhalt des Stapelzeigers SP in das Adreßregister geladen. Anschlie-Bend wird der auf 32 Bit erweiterte Distanzwert zum SP addiert. Über den negativen Distanzwert ist es möglich, gezielt Stapelfelder freizuzgeben.

#### Befehlsformat:

| 15 | 14               | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0  |
|----|------------------|----|----|----|----|---|---|---|---|---|---|---|---|-------|----|
| 0  | 1                | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 0 | 1 | 0 | R | egist | er |
|    | Adreßdistanzwert |    |    |    |    |   |   |   |   |   |   |   |   |       |    |

Bezeichnungen:

Register

 gibt das Adreßregister an, über das die Verbindung her-

gestellt wird.

Adreßdistanzwert - wird als Zweiterkomplement gebildet und zum Stapelzeiger

hinzuaddiert.

### LSL, LSR \* Logical Shift Left, Right Logische Verschiebung links, rechts

Operation:

(Ziel) verschoben um <Stellenzahl>→Ziel

Assemblersyntax:

LSL Dx,Dy ; LSR Dx,Dy

LSL #<Daten>,Dn; LSR #<Daten>,Dn

LSL < EA >; LSR < EA >

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Die Bits des Operanden werden in der angegebenen Richtung logisch verschoben. Bei einer Registerverschiebung kann der Verschiebungsfaktor auf zwei verschiedene Weisen angegeben werden:

durch einen unmittelbaren Wert (von 1 bis 8)durch einen Wert in einem Datenregister

Der Inhalt einer Speicherstelle kann nur um ein Bit verschoben werden, und der Operand muß immer ein Wort sein.



Befehlsformat: Verschiebung eines Registers

| 15 | 14 | 13 | 12 | 11 10            | 9 | 8  | 7           | 6 | 5   | 4 | 3 | 2 | 1     | 0  |  |
|----|----|----|----|------------------|---|----|-------------|---|-----|---|---|---|-------|----|--|
| 1  | 1  | 1  | 0  | Anzah<br>Registe |   | dr | Opera<br>mo |   | i/r | 0 | 1 | R | egist | ег |  |

#### Bezeichnungen:

Anzahl/Register bestimmt die Anzahl der Ver-

schiebungen oder das Register, das diese Zahl enthält.

i/r - i/r=0 - der Verschiebungs-

faktor (von 1 bis 8) ist im Be-

fehl enthalten.

i/r=1 - der Verschiebungsfaktor (modulo 64) ist im angegebenen Register enthal-

ten.

dr gibt die Richtung der Ver-

schiebung an.

dr=0 - Verschiebung nach

rechts.

dr=1 - Verschiebung nach

links.

Operationsmodus - 00 - Byte

01 – Wort

10 - Doppelwort

Register - gibt die Nummer des Daten-

registers an, dessen Inhalt ver-

schoben werden soll.

#### Befehlsformat. Verschiebung einer Speicherstelle



Effektive Adresse

#### Bezeichnungen:

dr - bestimmt die Richtung der

Verschiebung.

dr=0 - Verschiebung nach

rechts.

dr=1 - Verschiebung nach

links.

Effektive Adresse – bestimmt den Operanden, der verschoben werden soll.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | _     | _                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | _     | -                    |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

#### Bedingungscodes:

|   | X | N | Z | V | C |
|---|---|---|---|---|---|
| ı | В | В | В | 0 | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird durch das letzte aus dem Operanden geschobene Bit bestimmt. Es wird auf 0 gesetzt, wenn keine Verschiebung stattgefunden hat.
- X wird wie C durch das letzte aus dem Operanden geschobene Bit bestimmt. Es wird nicht beeinflußt, wenn keine Verschiebung stattgefunden hat.

### MOVE Move Data from Source to Destination Transportiere Daten von der Quelle zum Ziel

Operation:

(Quelle)→Ziel

Assemblersyntax: MOVE <EA>,<EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung:

Der Quelloperand wird zum Ziel transportiert. Die Daten werden bei der Übertragung getestet, und dementsprechend werden die Bedingungscodes

gesetzt.

#### Befehlsformat:



#### Bezeichnungen:

Operationsmodus - 01 - Byte

11 - Wort

Ziel

10 - Doppelwort bestimmt das Ziel.

#### Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| On               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            |       |                      |
| ~ (An)           | 100   | Nummer des Registers | d(PC, Xi)        |       | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

#### Ouelle

 bestimmt den zu übertragenden Quelloperanden.

#### Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register              | Adressierungsarl | Modus | Register             |
|------------------|-------|-----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers  | d(An Xi)         | 110   | Nummer des Registers |
| An*              | 001   | Nurnmer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers  | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers  | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers  | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers  | unmittelbar      | 111   | 100                  |

<sup>\*</sup> Fur die Byteoperationen ist die Adressierungsart Adreffregister direkt verboten

#### Bedingungscodes.

| - | X | N | Z | V | С |
|---|---|---|---|---|---|
|   | _ | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

### MOVE zum CCR Transportiere Daten zum CCR

Move to CCR

Operation:

(Quelle)→CCR

Assemblersyntax:

MOVE < EA>, CCR

Operandenlänge:

Wort

Beschreibung:

Der Quelloperand wird zum Bedingungscoderegister transportiert. Der Operand ist zwar ein Wort, aber nur die 8 unteren Bits beeinflussen das CCR, die 8

höheren Bits werden ignoriert.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3 | 2  | 1     | 0  |
|----|----|----|----|----|----|---|---|---|---|---|-------|---|----|-------|----|
| 0  | 1  | 0  | 0  | 0  | 1  | 0 | 0 | 1 | 1 | N | /lodu | s | Re | egist | er |
|    |    |    |    |    |    |   |   |   |   |   |       |   |    |       |    |

Effekt ve Adresse

Bezeichnungen:

Effektive Adresse - bestimmt den Quelloperanden.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsad | Modus | Register             | Adress-erungsart | Modus | Register             |
|-----------------|-------|----------------------|------------------|-------|----------------------|
| Dn              | 000   | Nummer des Registers | d(An, XI)        | 110   | Nummer des Registers |
| An              | _     | _                    | Abs.W            | 111   | 000                  |
| (An)            | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +          | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)          | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)           | 101   | Nummer des Registers | unm₁ttelbar      | 111   | 100                  |

Bemerkung: MOVE zum CCR ist eine auf ein Wort erweiterte Operation. AND, OR und EOR mit CCR sind Operationen, die sich auf ein Byte beziehen.

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird entsprechend dem Bit 3 des Quelloperanden gesetzt.
- Z wird entsprechend dem Bit 2 des Quelloperanden gesetzt.
- V wird entsprechend dem Bit 1 des Quelloperanden gesetzt.
- C wird entsprechend dem Bit 0 des Quelloperanden gesetzt.
- X wird entsprechend dem Bit 4 des Quelloperanden gesetzt.

### MOVE zum SR Move to SR Transportiere Daten zum SR

Operation:

Wenn der Prozessor im Supervisor Modus ist, dann:

(Quelle)→SR

Sonst Ausnahmezustand "Privilegverletzung".

Assemblersyntax:

MOVE <EA>,SR

Operandenlänge:

Wort

Beschreibung:

Der Quelloperand wird nur zum Statusregister SR übertragen, wenn sich der Prozessor im Supervisor-Modus befindet. Andernfalls wird der Ausnahmezu-

stand "Privilegverletzung" ausgelöst.

#### Befehlsformat:



Effektive Adresse

#### Bezeichnungen:

Effektive Adresse – bestimmt den Quelloperanden.

### Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Ðn               | 000   | Nummer des Registers | d(An, XI)        | 110   | Nummer des Registers |
| An               | -     | 440                  | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

Die Bedingungscodes werden dem Quelloperanden entsprechend gesetzt.

### **MOVE von SR**

Move from SR Transportiere Daten vom SR

Operation:

SR-Ziel

Assemblersyntax:

MOVE SR, <EA>

Operandenlänge:

Wort

Beschreibung:

Der Inhalt des Statusregisters SR wird zur Ziel-

adresse übertragen.

Befehlsformat:



Effektive Adresse

#### Bezeichnungen:

Effektive Adresse – bestimmt den Zieloperanden.

Die folgenden Adressierungsarten sind zulässig:

| Adresslerungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Reg sters | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Reg sters | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Reg sters | d(PC)            | -     | _                    |
| (An)             | 100   | Nummer des Registers | d(PC,X)          | -     | -                    |
| d(An)            | 101   | Nummer des Reg sters | unmittelbar      |       | 1                    |

### **MOVE USP**

Move User Stack Pointer Transportiere Daten von und nach Benutzerstapelzeiger

Operation:

Wenn der Prozessor im Supervisor-Modus ist, dann:

USP→An oder An→USP

Sonst Ausnahmezustand "Privilegverletzung".

Assemblersyntax:

MOVE USP, An

oder

MOVE An, USP

Operandenlänge:

Doppelwort

Beschreibung:

Der Inhalt des Benutzerstapelzeigers wird vom oder

zum angegebenen Adreßregister übertragen.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1     | 0  |
|----|----|----|----|----|----|---|---|---|---|---|---|----|---|-------|----|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 0 | dr | R | egist | er |

Bezeichnungen:

dr

- gibt die Übertragungsrichtung

an.

dr=0 - An + USP $dr=1 - USP \rightarrow An$ 

Register

 gibt das Adreßregister an, das beim Transfer verwendet

wird.

### MOVEA Move Address Transportiere Adresse

Operation:

(Quelle)→Ziel

Assemblersyntax:

MOVEA <EA>,An

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Der Quelloperand wird zum Adreßregister übertra-

gen. Operanden der Länge 16 werden vor der Übertragung vorzeichenbehaftet auf 32 Bits erweitert.

Befehlsformat:

15 14 13 12 -11 10 8 3 Operations-0 0 Register Modus Register modus 7iel Quelle

Bezeichnungen:

Ziel

Operationsmodus

- gibt die Länge des zu übertra-

genden Operanden an.

11 - Wortoperation mit Er-

weiterung auf 32 Bits.

10 - Doppelwortoperation gibt das verwendete Adreßre-

gister an.

Ouelle - gibt den Quelloperanden an.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

### MOVEM \*

#### Move Multiple Registers Transportiere mehrere Register

Operation:

mehrere Register-Ziel

oder

(Quelle→mehrere Register

Assemblersyntax:

MOVEM < Registerliste > , < EA >

oder

MOVEM <EA>, < Registerliste>

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Die angegebenen Register werden von oder zum Speicher transportiert, beginnend mit derjenigen Speicherstelle, die durch die effektive Adresse bestimmt wird. Das Erweiterungswort des Befehls wird als Registermaske bezeichnet. Wenn ein Register von dem Befehl betroffen werden soll, wird das entsprechende Bit in der Registermaske auf I gesetzt Werden nun die Worte zu den Registern übertragen, erfolgt eine vorzeichenbehaftete Erweiterung auf 32 Bits, wobei dies für die Adreßregister sowie für die Datenregister gilt. MOVEM erlaubt die drei folgenden Adressierungsarten:

- Adreßregister indirekt mit Predekrementierung.
   Adreßregister indirekt mit Postinkrementierung.
- Steuerung (alle Adressierungsarten zum Zugriff zu Speicheroperanden ohne Größenangaben).

Bei der Adressierung mit Predekrementierung werden die Register in der Reihenfolge Adreßregister A7 bis A0 und danach Datenregister D7 bis D0 übertragen. Für die beiden anderen Adressierungsarten geschieht der Transport in der umgekehrten Reihenfolge, und zwar werden zuerst die Register D0 bis D7 und dann A0 bis A7 übertragen.

#### Transport vom Register zum Speicher

Folgende Adressierungsarten sind zulässig:

Adreßregister indirekt :(An)

Predekrementierung :-(An)
indirekt mit Adreßdistanz:D(An)
indirekt mit Index :D(An,XI)
absolut kurz und lang :Abs.W,Abs.L

Im Fall der Predekrementierung hat die Registermaske folgende Struktur:



Im Speicher werden die Register in der Reihenfolge der abnehmenden Adressen (Predekrementierung) übertragen. Das erste Register wird an der effektiven Adresse minus 2 (Predekrementierung für Worte) geschrieben. Durch die Registermaske ist genau festgelegt, welche Register betroffen sind.

Im Fall der Adressierungsart Steuerung hat die Registermaske folgende Struktur:



Die Register werden zu der angegebenen Adresse in der Reihenfolge der aufsteigenden Adressen übertragen.

#### Transport vom Speicher zum Register

Folgende Adressierungsarten sind zulässig:

Adreßregister indirekt :(An)
Predekrementierung :(An)+
indirekt mit Adreßdistanz:D(An)
indirekt mit Index :D(An,XI)

absolut kurz und lang

:Abs.W,Abs.L

relativ zum PC

:D(PC)

- relativ zum PC mit Index :D(PC,XI)

#### Im Fall der Postinkrementierung:

Die Register werden mit dem Inhalt der angegebenen Speicherstellen geladen. Danach wird der Inhalt der nächsten Speicherselder in der Reihenfolge der aufsteigenden Adressen übertragen.

Für den Fall der Postinkrementierung und der Adressierungsart Steuerung hat die Registermaske folgende Struktur:

| 15 |    |            |    |    |    |    |    |    |    |    |    |    | -  |    | _  |
|----|----|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| A7 | A6 | <b>A</b> 5 | A4 | А3 | A2 | A1 | A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

#### Befehlsformat:

| 0 | rma | t: |    |    |    |    |   |        |      |                           | _ | Effe          | dive | Adre | sse   |    |
|---|-----|----|----|----|----|----|---|--------|------|---------------------------|---|---------------|------|------|-------|----|
|   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7    | 6                         | 5 | 4             | 3    | 2    | 1     | 0  |
|   | 0   | 1  | 0  | 0  | 1  | dr | 0 | 0      | 1    | Ope-<br>rations-<br>modus | N | <b>/lod</b> u | \$   | R    | egist | er |
|   |     |    |    |    |    |    | R | egisti | erma | aske                      |   |               |      |      |       |    |

#### Bezeichnungen:

dг

 gibt die Transportrichtung an. dr=0 - Register zum

Speicher

dr=1 - Speicher zum

Register

**Operationsmodus** 

gibt die Länge der für den Transport benutzten Register

0 - Wort

1 - Doppelwort

Effektive Adresse

- gibt die Speicheradresse an, zu oder ab der ein Transport

durchgefuhrt wird.

Für den Fall des Transportes von Registern zum Speicher sind folgende Adressierungsarten zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               | _     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | -     | -                    | d(PC)            | -     | _                    |
| - (An)           | 100   | Nummer des Registers | d(PC, XI)        | -     |                      |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       | _                    |

## Für den Fall des Transportes vom Speicher zu den Registern sind folgende Adressierungsarten zulässig:

| Adress erungsart | Modus | Register             | Adressierungsart | Modus | Register            |
|------------------|-------|----------------------|------------------|-------|---------------------|
| Dn               | -     |                      | d(An, Xi)        | 110   | Nummer des Register |
| An               | -     | - :                  | Abs W            | 111   | 000                 |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                 |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                 |
| (An)             | -     | -                    | d(PC, Xi)        | 111   | 011                 |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     |                     |

### MOVEP \* Move Peripheral Data Übertrage periphere Daten

Operation:

(Quelle)→Ziel

Assemblersyntax:

MOVEP Dx, D(Ay)

odei

MOVEP D(Ay), Dx

Operandenlänge:

Wort, Doppelwort

Beschreibung:

Die Daten werden zwischen den Datenregistern und abwechselnd aufeinanderfolgenden geraden oder aufeinanderfolgenden ungeraden Speicherstellen übertragen. Daher erfolgt die Adreßinkrementierung mit der Schrittweite 2. Das obere Byte eines Datenregisters wird als erstes übertragen, das untere als letztes. Die Speicheradresse wird stets in der Art "indirekt mit Adreßdistanzwert" vorgegeben. Bei einer geraden Adresse werden alle Übertragungen auf der oberen Hälfte des Datenbusses durchgeführt, bei einer ungeraden auf der unteren Hälfte.

Im folgenden Beispiel wird die Übertragung eines Doppelwortes von oder zu einer geraden Speicheradresse veranschaulicht:

Byteorganisation des Registers:

| 31 :                | 24 | 23 10                    | 6 | 15 8                       | 7                     | 0 |
|---------------------|----|--------------------------|---|----------------------------|-----------------------|---|
| höchstwertiges Byte |    | zweilhöchstwartiges Byte | , | zweitniederwarligstes Byta | niederwertigstes Byte | 7 |

#### Byteorganisation des Speichers:

|              | 10                         | 0 | • | U |
|--------------|----------------------------|---|---|---|
| aufsteigende | höchstwertiges Byte        |   |   |   |
| Adressen     | zweithöchstwertiges Byte   |   |   |   |
|              | zweitniederwertigstes Byte |   |   |   |
| •            | niederwertigstes Byte      |   |   |   |

Im folgenden Beispiel wird die Übertragung eines Wortes von oder zu einer ungeraden Speicheradresse veranschaulicht:

#### Byteorganisation des Registers:

| 31 | 24 23 | 16 15     | 8 7                  | 0        |
|----|-------|-----------|----------------------|----------|
|    |       | höherwert | iges Byle niederwert | ges Byte |

#### Byteorganisation des Speichers:

| E A 2                    | 15       | 8 | 7                   | 0 |
|--------------------------|----------|---|---------------------|---|
| aufsteigende<br>Adressen |          |   | höherwertiges Byte  |   |
|                          | <b>+</b> |   | niederwertiges Byte |   |

#### Befehlsformat:

| 15 | 14               | 13 | 12 | 11 | 10              | 9 | 8 | 7              | 6 | 5 | 4 | 3 | 2 | 1              | 0 |
|----|------------------|----|----|----|-----------------|---|---|----------------|---|---|---|---|---|----------------|---|
| 0  | 0                | 0  | 0  |    | Daten<br>egiste |   |   | eratio<br>nodu |   | 0 | 0 | 1 | 1 | \dref<br>egist |   |
|    | Adreßdistanzwert |    |    |    |                 |   |   |                |   |   |   |   |   |                |   |

#### Bezeichnungen:

Datenregister

 gibt das Datenregister an, von oder zu dem Daten übertragen werden.

Operationsmodus

gibt die Übertragungsrichtung und -länge an.

100 - Wort: Transport vom

Speicher zu Registern

101 - Doppelwort: Transport vom Speicher zu Registern. 110 - Wort: Transport von den Registern zum Speicher. 111 - Doppelwort: Transport

von den Registern zum Spei-

cher.

Adreßregister

- bestimmt das Adreßregister, das bei der Adressierung mit Distanzwert verwendet wird.

Adreßdistanzwert – gibt die Verschiebung an, die bei der Berechnung der Operandenadresse Verwendung findet.

## MOVEQ \* Move Quick Übertrage schnell

Operation:

<unmitttelbare Daten>→,Dn

Assemblersyntax:

MOVEO #<Daten>Ziel

Operandenlänge:

Doppelwort

Beschreibung.

Ein unmittelbares Datenelement wird in ein Datenregister übertragen. Es ist, mit 8 Bit codiert, direkt im Befehlswort enthalten und wird vor der Befehlsausführung auf 32 Bits vorzeichenbehaftet erweitert.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8 | 7 | 6 | 5 | 4    | 3    | 2 | 1 | 0 |
|----|----|----|----|----|--------|----|---|---|---|---|------|------|---|---|---|
| 0  | 1  | 1  | 1  | R  | egisti | er | 0 |   |   | ا | Date | nwer | t |   |   |

#### Bezeichnungen:

Register

- bestimmt das als Ziel verwen-

dete Datenregister.

Datenwert

steht f
 ür das 8 Bits lange Datenelement, das vor dem Transfer auf 32 Bits erweitert wird

#### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

### MULS Signed Multiply Multiplikation mit Vorzeichen

Operation:

(Quelle)\*(Ziel)-Ziel

Assemblersyntax:

MULS < EA>, Dn

Operandenlänge:

Wort

Beschreibung:

Zwei 16-Bit-Operanden mit Vorzeichen werden multipliziert, und der Zieloperand wird mit dem mit Vorzeichen versehenen 32-Bit-Ergebnis überschrieben. Von dem in einem Register enthaltenen Operanden werden nur die 16 unteren Bits berücksichtigt.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8 | 7 | 6 | 5 | 4     | 3 | 2 | 1     | 0  |
|----|----|----|----|----|--------|----|---|---|---|---|-------|---|---|-------|----|
| 1  | 1  | 0  | 0  | R  | egisti | er | 1 | 1 | 1 | A | /lodu | s | R | egist | er |
|    |    |    |    |    |        |    |   |   |   |   |       |   |   |       |    |

Effektive Adresse

#### Bezeichnungen:

Register

- gibt das als Ziel verwendete

Datenregister an.

Effektive Adresse - definiert den Quelloperanden.

### Die folgenden Adressierungsarten sind zulässig:

| Adress er ungsart | Modus     | Register             | Adressierungsart | Modus | Register             |
|-------------------|-----------|----------------------|------------------|-------|----------------------|
| Dn                | Dn 000 Nu |                      | d(An, Xi)        | 110   | Nummer des Registers |
| An                | _         | ***                  | Abs W            | 111   | 000                  |
| (An)              | 010       | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +            | 011       | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)              | 100       | Nummer des Registers | σ(PC, Xi)        | 111   | 011                  |
| d(An)             | 101       | Nummer des Registera | unmittelbar      | 111   | 100                  |

### Bedingungscodes:

| İ | X | N | Z | V | C |
|---|---|---|---|---|---|
|   |   | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

### **MULU**

#### Unsigned Multiply Multiplikation ohne Vorzeichen

Operation:

(Quelle)\*(Ziel)→Ziel

Assemblersyntax:

MULU <EA>,Dn

Operandenlänge:

Wort

Beschreibung:

Zwei 16-Bit-Operanden ohne Vorzeichen werden multipliziert, und das Datenregister des Zieloperanden wird mit dem 32-Bit-Ergebnis ohne Vorzeichen überschrieben. Von dem in einem Register enthaltenen Operanden werden nur die 16 unteren Bits

berücksichtigt.

#### Befehlsformat:

| _ |   |   |   | _ |   | 10     | _  | - |   | _ | _ | ,    | _ | _ |       | _  |
|---|---|---|---|---|---|--------|----|---|---|---|---|------|---|---|-------|----|
|   | 1 | 1 | 0 | 0 | R | egiste | er | 0 | 1 | 1 | ٨ | Nodu | s | R | egist | er |
|   |   |   |   |   |   |        |    |   |   |   |   | ~_   |   | _ |       |    |

Effektive Adresse

#### Bezeichnungen:

Register

- gibt das als Ziel verwendete

Datenregister an.

Effektive Adresse - defir den.

definiert den Quelloperan-

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Reg sters | unmittelbar      | 111   | 100                  |

### Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| - | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt. C wird immer auf 0 gesetzt. X nicht beeinflußt.

### NBCD \* Negate Decimal with Extend Decimal Negation mit Erweiterungsbit

Operation:

0-(Ziel)<sub>10</sub>-X→Ziel

Assemblersvntax:

NBCD <EA>

Operandenlänge:

Byte

Beschreibung:

Der Zieloperand und das Erweiterungsbit werden von 0 subtrahiert. Die Operation kann nur byteweise mit dezimaler Arithmetik durchgeführt werden und wird vorwiegend für BCD-Zahlen verwendet. Der Zieloperand wird mit dem Ergebnis überschrieben. Falls das Erweiterungsbit X gleich 0 ist, wird das Zehnerkomplement des Zieloperanden gebildet. Ist X gleich 1, dann wird ein Neunerkomplement verwendet.

#### Befehlsformat:



Effektive Adresse

Bezeichnungen:

Effektive Adresse - definiert den Zieloperanden.

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart       | Modus | Register             |
|------------------|-------|----------------------|------------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)              | 110   | Nummer des Registers |
| Ап               | _     | -                    | Abs.W                  | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L                  | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)                  | -     | -                    |
| - (An)           | 100   | Nummer des Registers | d(PC, X <sub>1</sub> ) | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar            | -     | -                    |

Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | U | В | U | В |

- N undefiniert.
- Z wird auf 0 gesetzt, wenn das Ergebnis nicht 0 ist, sonst nicht beeinflußt
- V undefiniert.
- C wird auf 1 gesetzt, wenn ein dezimaler Übertrag anfällt, sonst auf 0.
- X wie C.

Bei mehrfach genauen Berechnungen ist es notwendig, daß das Bit Z vorher mit 1 initialisiert wird (siehe auch Programm 7 im Kapitel "Anwenderprogramme").

NEG

Negate Negation

Operation:

0-(Ziel)→Ziel

Assemblersyntax:

NEG <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Der Zieloperand wird von 0 subtrahiert und vom

Ergebnis überschrieben.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6              | 5 | 4    | 3  | 2 | 1     | 0  |
|----|----|----|----|----|----|---|---|-------------|----------------|---|------|----|---|-------|----|
| 0  | 1  | 0  | 0  | 0  | 1  | 0 | 0 | Opera<br>mo | ations-<br>dus | 1 | Modu | ıs | R | egist | er |

Effektive Adresse

Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - definiert den Zieloperanden.

| Adresslerungsart | Modus               | Register             | Adressierungsart | Modus | Register             |
|------------------|---------------------|----------------------|------------------|-------|----------------------|
| Dn               | 000                 | Nummer des Registers | d(An Xi) 110     |       | Nummer des Registers |
| Ал               | -                   | 4dia                 | Abs W            | 111   | 000                  |
| (An)             | (An) 010 Nummer des |                      | Aps L            | 111   | 001                  |
| (An) +           | 011                 | Nummer des Registers | d(PC)            | -     | +                    |
| ~ (An)           | 100                 | Nummer des Registers | d(PC, Xt)        |       | -                    |
| d(An)            | 101                 | Nummer des Registers | unmittelbar      | ] -   | -                    |

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- V wird auf 1 gesetzt, wenn ein Überlauf anfällt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein negativer Übertrag anfällt, sonst auf 0.
- X wie C.

## NEGX Negate with Extend Negation mit Erweiterungsbit

Operation:

 $0-(Ziel)-X\rightarrow Ziel$ 

Assemblersyntax: NEGX <EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung:

Der Zieloperand und das Erweiterungsbit werden

gemeinsam von 0 subtrahiert, und der Zieloperand

wird vom Ergebnis überschrieben.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6              | 5 | 4     | 3     | 2     | 1     | 0  |
|----|----|----|----|----|----|---|---|-------|----------------|---|-------|-------|-------|-------|----|
| 0  | 1  | 0  | 0  | O  | 0  | 0 | 0 | Орега | itions-<br>dus | N | /lodu | s     | R     | egist | er |
|    |    |    |    |    |    |   |   |       |                |   | Effo  | ktovo | - Adv |       |    |

Effektive Adresse

#### Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - definiert den Zieloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Reg sters | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| - (An)           | 100   | Nummer des Registers | d(PC, Xı)        |       | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       | -                    |

### Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
| В | U | В | U | В |

- N undefiniert.
- Z wird auf 0 gesetzt, wenn das Ergebnis nicht 0 ist, sonst nicht beeinflußt.
- V undefiniert.
- C wird auf 1 gesetzt, wenn ein negativer Übertrag anfällt, sonst auf 0
- X wie C.

Bei mehrfach genauen Berechnungen, bei denen dieser Befehl vorzugsweise Verwendung findet, ist es notwendig, daß das Bit Z vorher mit 1 initialisiert wird (siehe auch Programm 7 im Kapitel "Anwenderprogramme").

### NOP

#### No Operation Keine Operation

Operation:

\_

Assemblersyntax:

NOP

Operandenlänge:

Beschreibung:

Es wird keine Operation durchgeführt. Der Zustand

des Prozessors bleibt unverändert. Der PC gibt an, welcher Befehl als nächster ausgeführt werden soll.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |

Bedingungscodes. nicht beeinflußt

## **NOT**

#### **Logical Complement Einerkomplement**

Operation:

(Ziel)→Ziel

Assemblersyntax: NOT <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Es wird das Einerkomplement des Zieloperanden

gebildet.

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6              | 5 | 4     | 3 | 2 | 1     | 0  |
|----|----|----|----|----|----|---|---|-------|----------------|---|-------|---|---|-------|----|
| 0  | 1  | 0  | 0  | 0  | 1  | 1 | 0 | Opera | ations-<br>dus | N | /lodu | s | R | egist | er |
|    |    |    |    |    |    |   |   |       |                |   | _     |   |   |       |    |

Effektive Adresse

#### Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - definiert den Zieloperanden.

| Adressierungsart | Modus | Register             | Adresslerungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Ðn               | 000   | Nummer des Registers | d(An Xi)         | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | _     |                      |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | _     |                      |

|   | X | N | Z | V | С |
|---|---|---|---|---|---|
| į | - | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt. X nicht beeinflußt.

### OR

#### Logical OR Logisches ODER

Operation:

(Ziel)V(Quelle)→Ziel

Assemblersyntax:

OR <EA>,Dn

oder

OR Dn, <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Ziel- und Quelloperand werden durch ein logisches ODER verknüpft, und das Ergebnis überschreibt den Zieloperanden. Der Inhalt der Adreßregister darf nicht als Operand verwendet werden.

#### Befehlsformat:



### Bezeichnungen:

Register – gibt das Datenregister an.

Operationsmodus

Byte Wort Doppelwort Operation

Effektive Adresse – definiert den Quelloperanden.

Dann sind die folgenden Adressierungsarten zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       |                      | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs. L           | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| · (An)           | 100   | Nummer des Registers | d(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

Effektive Adresse – definiert den Zieloperanden. Dann sind die folgenden Adressierungsarten zulässig:

| Adressierungsart | Modus                          | Register             | Adressierungsart | Modus | Register             |
|------------------|--------------------------------|----------------------|------------------|-------|----------------------|
| Dn               | Dn -                           |                      | d(An, XI)        | 110   | Nummer des Registers |
| An               | -                              | -                    | Abs W            | 111   | 000                  |
| (An)             | (An) 010 Nummer des Register   |                      | Abs.L            | 111   | 001                  |
| (An) +           | 011                            | Nummer des Registers | d(PC)            | -     |                      |
| -(An)            | 100                            | Nummer des Registers | a(PC, Xi)        | -     | -                    |
| d(An)            | d(An) 101 Nummer des Registers |                      | unmittelbar      | -     | _                    |

| X | N | Z | V | C |
|---|---|---|---|---|
|   | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

### ORI

#### Logical OR Immediate Logisches ODER unmittelbar

Operation: <unmittelbare Daten>V(Ziel)→Ziel

Assemblersyntax: ORI #<Daten>,<EA>

Operandenlange: Byte, Wort, Doppelwort

Beschreibung: Das unmittelbare Datenelement und der Zielope-

rand werden durch ein logisches ODER verknüpft, und der Zieloperand wird mit dem Ergebnis überschrieben. Die Länge der unmittelbaren Daten

stimmt mit dem Datenlängencode überein.

#### Befehlsformat:



Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - definiert den Zieloperanden.

| Adressierungsart | Modus | Reg ster             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | _                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs. L           | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     |                      |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 1 -   | -                    |

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt. C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

## ORI mit CCR Logisches ODER unmittelbar mit CCR

# Logical OR Immediate to CCR

Operation:

<unmittelbare Daten>VCCR-CCR

Assemblersyntax:

ORI #<Daten>,CCR

Operandenlänge:

Byte

Beschreibung.

Das unmittelbare 8 Bit Datenelement und das Bedingungscoderegister werden durch ein logisches ODER verknupft. Das Ergebnis wird in das untere Byte des Statusregisters SR geschrieben.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4     | 3     | 2    | 1 | 0_ |
|----|----|----|----|----|----|---|---|---|---|-----|-------|-------|------|---|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 1   | 1     | 1     | 1    | 0 | 0  |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   | 8-B | it-Da | itenv | vert |   |    |

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Bit 3 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- Z wird auf 1 gesetzt, wenn das Bit 2 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- V wird auf 1 gesetzt, wenn das Bit 1 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- C wird auf 1 gesetzt, wenn das Bit 0 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- X wird auf 1 gesetzt, wenn das Bit 4 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.

## ORI mit SR Logical OR Immediate to SR Logisches ODER unmittelbar mit SR

Operation:

Wenn der Prozessor im Supervisor-Modus ist, dann:

<unmittelbare Daten>VSR-SR

Sonst tritt der Ausnahmezustand "Privilegverlet-

zung" auf.

Assemblersyntax:

ORI #<16-Bit-Daten>,SR

Operandenlänge:

Wort

Beschreibung:

Das unmittelbare 8-Bit-Datenelement und das Statusregister SR werden durch ein logisches ODER verknüpft. Das Ergebnis wird in das Statusregister SR geschrieben. Wenn der Prozessor sich dabei nicht im Supervisor-Modus befindet, wird der Ausnahmezustand "Privilegverletzung" mit der Vektornummer 8 erzeugt

Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10   | 9     | 8    | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|------|-------|------|------|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0    | 0    | 1 | 1 | 1 | 1 | 1 | 0 | 0 |
|    |    |    |    |    | 16-B | it-Da | tenw | /ert |   |   |   |   |   |   |   |

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Bit 3 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- Z wird auf 1 gesetzt, wenn das Bit 2 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- V wird auf 1 gesetzt, wenn das Bit 1 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- C wird auf 1 gesetzt, wenn das Bit 0 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.
- X wird auf 1 gesetzt, wenn das Bit 4 des Datenelementes eine 1 enthält, sonst bleibt es unverändert.

## PEA \* Push Effective Addresse auf den Stapel

Operation:

 $Ziel \rightarrow -(SP)$ 

Assemblersyntax: PEA <EA>

Operandenlänge:

Doppelwort

Beschreibung:

Die effektive Adresse wird berechnet und auf dem

Stapel abgelegt. Dabei wird der Stapelzeiger SP um 4

vermindert.

#### Befehlsformat:



Effektive Adresse

#### Bezeichnungen:

Effektive Adresse - gibt die auf den Stapel zu rettende Adresse an.

### Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsarl | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | _     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       | ***                  | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | -     | -                    | d(PC)            | 111   | 010                  |
| - (An)           | -     | -                    | d(PC Xi)         | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       |                      |

Bedingungscodes: nicht beeinflußt.

## RESET

#### Reset External Devices Zurücksetzen externer Einheiten in den Grundzustand

Operation:

Wenn der Prozessor im Supervisor-Modus ist, dann wird der Reset-Ausgang entsprechend gesetzt, ansonsten geht der Prozessor in den Ausnahmezu-

stand "Privilegverletzung".

Assemblersyntax:

RESET

Operandenlänge:

Beschreibung:

Die Reset-Leitung wird für die Dauer von 124 Taktzyklen aktiviert, um die externen Bausteine in den Grundzustand zurückzusetzen. Mit Ausnahme des PC, der den nächsten auszuführenden Befehl angibt, bleibt der Zustand des Prozessors unverändert.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |  |

Bedingungscodes: nicht beeinflußt.

## ROL, ROR \*Ringverschiebung links, rechts ohne Erweiterungsbit

Rotate Left, Right without Extend

Operation:

(Ziel)ringverschoben um<Stellenzahl>→Ziel

Assemblersyntax:

ROL Dx, Dy

; ROR Dx, Dy

oder

ROL #<Daten>,Dn; ROR #<Daten>,Dn

oder

ROL <EA>

; ROR <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Die Bits eines Operanden werden entsprechend der Richtung L oder R ringverschoben. Die Anzahl der Stellen, mit der die Ringverschiebung durchgeführt wird, kann auf zwei unterschiedliche Arten angegeben werden:

- durch einen unmittelbar im Befehl enthaltenen Wert:
- über ein Register.

Ein Speicherfeld kann immer nur um ein Bit maximal verschoben werden. Die zugelassene Operandenlange ist dabei ein Wort.



Befehlsformat:

Ringverschiebung eines Registers

| 15  | 14 | 13 | 12 | 11 | 10             | 9 | 8  | 7                   | 6 | 5   | 4 | 3 | 2 | 1     | 0  |
|-----|----|----|----|----|----------------|---|----|---------------------|---|-----|---|---|---|-------|----|
| 1 : | 1  | 1  | 0  | 1  | nzah<br>egiste |   | dr | <b>O</b> pera<br>mo |   | i/r | 1 | 1 | R | egisl | er |

#### Bezeichnungen:

Anzahl/Register

Ringverschiebung oder das Register, das den Verschie-

bungsfaktor enthält, an.

i/r

 i/r=0 – Verschiebungsfaktor ist in den Bits 9 bis 11 des Befehls enthalten Dabei entsprechen die Werte 0, 1,...,7 einer Verschiebung von 8.

 $1, \dots, 7$ .

i/r=1 - Verschiebungsfaktor (modulo 64) ist im angegebe-

nen Datenregister enthalten

dr

- gibt die Richtung der Ring-

verschiebung an. dr=0 - rechts

dr=1 - links

Operationsmodus -00 - Byte01 - Wort

10 - Doppelwort

Register

definiert die Nummer des Datenregisters, in dem der Ver-

schiebungsfaktor steht

#### Befehlsformat:

Ringverschiebung eines Speicherfeldes



Effektive Adresse

#### Bezeichnungen:

dr

- gibt die Richtung der Ring-

verschiebung an. dr=0 - rechts

dr=1-linksEffektive Adresse - gibt den Operanden an, in dem der Verschiebungsfaktor

enthalten ist.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, Xí)        | 110   | Nummer des Registers |
| An               | _     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | _                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

| X | N | Z | V | С |
|---|---|---|---|---|
| _ | В | В | 0 | В |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird durch das letzie aus dem Operanden herausgeschobene Bit bestimmt. Es wird auf 0 gesetzt, wenn keine Verschiebung stattgefunden hat.
- X nicht beeinflußt.

## ROXL, ROXR \* Ringverschiebung links, rechts mit Erweiterungsbit

Rotate Left. Right with Extend

Operation: (Ziel)ringverschoben um<Stellenzahl>→Ziel

Assemblersyntax: ROXL Dx, Dy ; ROXR Dx, Dy

> oder ROXL #<Daten>,Dn; ROXR #<Daten>,Dn

oder ROXL <EA> : ROXR <EA>

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung: Die Bits eines Operanden einschießlich eines Erweiterungsbits werden entsprechend der Richtung L oder R ringverschoben. Die Anzahl der Stellen, mit

der die Ringverschiebung durchgeführt wird, kann auf zwei unterschiedliche Arten angegeben werden:

- durch einen unmittelbar im Befehl enthaltenen Wert:

über ein Register.

Ein Speicherfeld kann immer nur um ein Bit maximal verschoben werden. Die zugelassene Operandenlänge ist dabei ein Wort.



| Befehlsformat: | Ringverschiebung eines Registers |
|----------------|----------------------------------|
|----------------|----------------------------------|

| 15 | 14 | 13 | 12 | 11 | 10    | 9  | 8  | 7     | 6      | 5   | 4 | 3 | 2 | 1     | 0  |
|----|----|----|----|----|-------|----|----|-------|--------|-----|---|---|---|-------|----|
| 1  | 1  | 1  | 0  |    | nzah  |    | dr | Opera | t ons- | i/r | 1 | 0 | R | egist | er |
|    |    |    |    | H  | egist | er |    | mo    | dus    |     |   |   |   |       |    |

#### Bezeichnungen:

Anzahl/Register

 gibt die Stellenanzahl für die Ringverschiebung oder das Register, das den Verschiebungsfaktor enthält, an.

1/1

i/r=0 - Verschiebungsfaktor ist in den Bits 9 bis 11 des Befehls enthalten. Dabei entsprechen die Werte 0, 1,...,7 einer Verschiebung von 8, 1,...,7

i/r=1 - Verschiebungsfaktor (modulo 64) ist im angegebenen Datenregister enthalten.

dr

- gibt die Richtung der Ring

verschiebung an. dr=0 - rechts dr=1 - links

Operationsmodus

- 00 - Byte 01 - Wort

10 - Doppelwort

Register

 definiert die Nummer des Datenregisters, in dem der Verschiebungsfaktor steht.

### Befehlsformat: Ringverschiebung eines Speicherfeldes



Effektive Adresse

#### Bezeichnungen:

dr

 gibt die Richtung der Ringverschiebung an.

dr=0 - rechts dr=1 - links

Effektive Adresse – gibt den Operanden an, in dem der Verschiebungsfaktor enthalten ist.

#### Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, Xi)        | 110   | Nummer des Registers |
| An               |       | -                    | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |
| ~ (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     |                      |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | 0 | В |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
- C wird durch das letzte aus dem Operanden herausgeschobene Bit bestimmt. Es wird auf 0 gesetzt, wenn keine Verschiebung stattgefunden hat.
- X wird durch das letzte aus dem Operanden herausgeschobene Bit bestimmt. Es bleibt unbeeinflußt, wenn keine Verschiebung stattgefunden hat.

### RTE

#### Return from Exception Rückkehr aus Ausnahmezustand

Operation: Wenn der Prozessor im Supervisor-Modus ist, dann:

 $(SP)+\rightarrow SR$  $(SP)+\rightarrow PC$ 

Sonst Ausnahmezustand "Privilegverletzung".

Assemblersyntax: RTE

Operandenlänge: -

Beschreibung: Die Inhalte des Statusregisters SR und des Pro-

grammzählers PC werden durch Zurückholen vom Systemstapelspeicher wiederhergestellt. Die z. Z. aktuellen Inhalte des SR und des PC werden nicht gerettet. Wenn der Prozessor nicht im Supervisor-Modus ist, geht er in den Ausnahmezustand "Privi-

legverletzung" mit der Vektornummer 8 über.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |

Bedingungscodes: Die Bedingungscodes werden entsprechend dem vom Stapel geholten Wort gesetzt.

## **RTR**

#### Return and Restore Condition Codes Rückkehr und Wiederherstellung der Bedingungscodes

Operation:

(SP)+→CCR

 $(SP)+\rightarrow PC$ 

Assemblersyntax:

RTR

Operandenlänge:

-

Beschreibung:

Die Inhalte des Bedingungscoderegisters CCR und des Programmzählers PC werden vom Stapel geholt. Die z. Z. aktuellen Inhalte des CCR und des PC werden nicht gerettet. Das Supervisor-Byte des Statusregisters bleibt unbeeinflußt.

#### Befehlsformat:

| 15 |   |   |   |   |   | - | _ | - | - | - |   | _ | _ | • | ~ |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |

Bedingungscodes:

Die Bedingungscodes werden entsprechend dem vom

Stapel geholten Wort gesetzt.

### RTS

#### Return from Subroutine Rückkehr aus dem Unterprogramm

Operation:

 $(SP)+\rightarrow PC$ 

Assemblersyntax:

RTS

Operandenlänge:

Beschreibung:

Der Inhalt des Programmzählers PC wird vom Stapel

geholt. Der z. Z. aktuelle Inhalt des PC wird nicht

gerettet.

Befehlsformat:

 15
 14
 13
 12
 11
 10
 9
 8
 7
 6
 5
 4
 3
 2
 1
 0

 0
 1
 0
 0
 1
 1
 1
 0
 0
 1
 1
 0
 0
 1

Bedingungscodes: nicht beeinflußt.

## SBCD \* Subtract Decimal with Extend Decimale Subtraktion mit Erweiterungsbit

Operation:

 $(Ziel)_{10}$ - $(Quelle)_{10}$ -X-Ziel

Assemblersyntax:

SBCD Dy, Dx

oder

SBCD - (Ay), (Ax)

Operandenlänge:

Byte

Beschreibung:

Subtraktion des Quelloperanden und des Erweiterungsbits vom Zieloperanden, wobei der Zieloperand mit dem Ergebnis überschrieben wird. Die Subtraktion wird arithmetisch für binär codierte Dezimalzahlen durchgeführt. Die Operanden sind entweder bei direkter Adressierung in Datenregistern oder beim Predekrementierungs-Modus in Speicherfeldern enthalten

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10           | 9  | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1           | 0  |
|----|----|----|----|----|--------------|----|---|---|---|---|---|-----|---|-------------|----|
| 1  | 0  | 0  | 0  | R  | egisti<br>Rx | er | 1 | 0 | 0 | 0 | 0 | R/M | R | egist<br>Ry | er |

#### Bezeichnungen:

Register Rx

gibt das Zielregister an.
 R/M=0 - Rx ist ein Datenre-

gister.

R/M=1 - Rx ist ein Adreßregister, das für die Predekrementierung verwendet wird.

R/M=0

Operand ist in einem Daten-

register enthalten.

R/M=1

- Operand ist in einem Spei-

cherfeld enthalten.

Register Ry

gibt das Quellregister an.
 R/M=0 - Ry ist ein Datenre-

gister.

R/M=1 - Ry ist ein Adreßregister, das für die Predrekrementierung verwendet wird.

#### Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
| В | U | В | U | В |

N undefiniert

Z wird auf 0 gesetzt, wenn das Ergebnis nicht 0 ist, sonst unverändert.

V undefiniert.

C wird auf 1 gesetzt, wenn ein dezimaler Übertrag anfällt, sonst auf 0.

X wie C.

Bei Operationen mit mehrfacher Genauigkeit ist es ratsam, vor der Ausführung Z mit 1 zu initialisieren (siehe auch Programm 7 im Kapitel "Anwenderprogramme").

Scc

Set according to Condition Bedingtes Setzen eines Bytes

Operation:

Wenn der Bedingungsausdruck wahr ist,

dann \$FF→Ziel sonst \$00→Ziel

Assemblersyntax.

Scc <EA>

Operandenlänge:

Byte

Beschreibung:

Der angegebene Bedingungsausdruck wird geprüft. Wenn der Test "Wahr" ergibt, wird das durch die effektive Adresse angegebene Byte auf \$FF gesetzt (Operand ist wahr). Ansonsten wird es auf 0 gesetzt (Operand ist falsch). Mit einem auf Scc folgenden NEG-Befehl ist es möglich, dem Byte sowohl den Wert \$00 als auch den Wert \$01 zuzuweisen. Die für cc zulassigen Bedingungen können der Tabelle für den Befehl DBcc entnommen werden.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10    | 9   | 8 | 7 | 6 | 5 | 4    | 3     | 2    | 1     | 0  |
|----|----|----|----|----|-------|-----|---|---|---|---|------|-------|------|-------|----|
| 0  | 1  | 0  | 1  | E  | Bedin | gun | g | 1 | 1 | ١ | /odu | s     | R    | egist | er |
|    |    |    |    |    |       |     |   |   |   | _ | Effo | ktivo | Adre | 1000  |    |

Bezeichnungen:

Bedingung

- ist eine der 16 Bedingungen aus der Tabelle für den Befehl

DBcc

Effektive Adresse - gibt die Zieladresse an, wohin das resultierende Byte geschrieben werden soll.

| Adressierungsart | Modus | Register             | Adresslerungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | -     | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     |                      |
| - (An)           | 100   | Nummer des Registers | d(PC Xi)         | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unm ttelbar      | _     | _                    |

Bedingungscodes: nicht beeinflußt.

## STOP

#### Load Statusregister and Stop Laden des Statusregisters und Stop

Operation:

Wenn der Prozessor im Supervisor-Modus ist, dann:

<unmittelbare Daten>→SR

Sonst Ausnahmezustand "Privilegverletzung".

Assemblersyntax:

STOP <16-Bit-Daten>

Operandenlänge:

: -

Beschreibung:

Das unmittelbare Datenelement wird in das Statusregister SR gebracht. Der Programmzähler PC zeigt auf den nächsten auszuführenden Befehl, und der Prozessor stoppt. Die Verarbeitung wird fortgesetzt, wenn TRACE aktiviert wird, eine Unterbrechung oder ein RESET auftritt.

Die Ausnahme TRACE wird eingeleitet, wenn das Bit T=1 ist, während der STOP-Befehl ausgeführt wird

Eine Unterbrechung kommt zum Zuge, wenn ihre Prioritätsebene höher als die derzeitige ist.

Ein externes RESET ruft immer die Ausnahmeverarbeitung RESET hervor. Wenn das dem Statusbit S entsprechende Bit des unmittelbaren Datenelements 0 ist, wird der Ausnahmezustand "Privilegverletzung" erzeugt.

#### Befehlsformat:



Bedingungscodes: Sie werden entsprechend dem unmittelbaren Daten element gesetzt.

### **SUB**

#### Subtract Binary Binäre Subtraktion

Operation:

(Ziel)-(Quelle)→Ziel

Assemblersyntax:

SUB <EA>,Dn

oder

SUB Dn, <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Binäre Subtraktion des Quelloperanden vom Ziel-

operanden und Ersetzen des Zieloperanden durch

das Ergebnis.

#### Befehlsformat:



Bezeichnungen:

Register – g

 gibt eins der 8 Datenregister an.

Operationsmodus

Byte Wort Doppelwort Operation

000 001 010 (⟨Dn⟩)-(⟨EA⟩)→⟨Dn⟩ 100 101 110 (⟨EA⟩)-(⟨Dn⟩)→⟨EA⟩

Effektive Adresse – bestimmt den Quelloperanden.

Dabei sind die folgenden Adressierungsarten zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| Aπ               | 001   | Nummer des Registers | Abs W            | 111   | 900                  |
| (An)             | 010   | Nummer des Registers | Abs. L           | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers | c(PC, Xi)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

<sup>\*</sup> Fur Byteoperationen ist die Adressierungsart "Adreßregister direkt" nicht erlaubt

Effektive Adresse – bestimmt den Zieloperanden. Dabei sind die folgenden Adressierungsarten zulässig:

| Adressierungsarf | Modus | Reg ster             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | -     | -                    | d(An, XI)        | 110   | Nummer des Registers |
| An               |       | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |
| - (An)           | 100   | Nummer des Registers | d(PC Xi)         | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     |                      |

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird bei Überlauf auf 1 gesetzt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein dezimaler Übertrag angefallen ist, sonst auf 0.
- X wie C.

## SUBA Subtract Address Subtraktion der Adresse

Operation:

(Ziel)-(Quelle)→Ziel

Assemblersyntax:

SUBA <EA>,An

Operandenlänge:

Wort, Doppelwort

Beschreibung.

Subtraktion des Quelloperanden von dem Zieloperanden und Ersetzen des Zieloperanden durch das Ergebnis. Ein Quelloperand mit Wortlange wird vor der Befehlsausführung vorzeichenbehaftet auf 32

Bits erweitert.

#### Befehlsformat:

|  | 15 | 14 | 13 | 12 | 11 | 10    | 9  | 8     | 7      | 6     | 5 | 4     | 3 | 2 | 1     | 0  |
|--|----|----|----|----|----|-------|----|-------|--------|-------|---|-------|---|---|-------|----|
|  | 1  | 0  | 0  | 1  | R  | egist | er | Opera | ations | nodus | N | /lodu | s | R | əgist | er |
|  |    |    |    |    |    |       | _  |       |        |       |   |       |   |   |       |    |

Effektive Adresse

Bezeichnungen:

Register

- gibt eins der 8 Adreßregister an. Sie werden stets als Ziel

verwendet.

Operationsmodus - 011 - Wort. Der Operand wird auf 32 Bits erweitert, und die Operation wird mit einem 32-Bit-Adreßregister durch-

geführt.

111 - Doppelwort

Effektive Adresse - bestimmt den Quelloperanden.

| \dressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, Xi)        | 110   | Nummer des Registers |
| An               | 001   | Nummer des Registers | Abs.W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | 111   | 010                  |
| - (An)           | 100   | Nummer des Registers | d(PC, XI)        | 111   | 011                  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | 111   | 100                  |

Bedingungscodes: nicht beeinflußt.

Effektive Adresse

### **SUBI**

#### Subtract Immediate unmittelbare Subtraktion

Operation:

(Ziel)-<unmittelbare Daten>→Ziel

Assemblersyntax: SUBI #<Daten>,<EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Subtraktion des unmittelbaren Datenelementes von dem Zieloperanden und Ersetzen des Zieloperanden

durch das Ergebnis.

#### Befehlsformat:



#### Bezeichnungen:

Operations modus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - bestimmt den Zieloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |  |
|------------------|-------|----------------------|------------------|-------|----------------------|--|
| Dri              | 000   | Nummer des Registers | d(An, XI)        | 110   | Nummer des Registers |  |
| An               |       | ~                    | Abs W            | 111   | 000                  |  |
| (An)             | 010   | Nummer des Registers | Abs L            | 111   | 001                  |  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | _     | -                    |  |
| - (An)           | 100   | Nummer des Registers | d(PC, Xi)        | -     | -                    |  |
| d(An)            | 101   | Nummer des Registers | unmittelbar      |       |                      |  |

| X | N | Z | V | С |  |
|---|---|---|---|---|--|
| В | В | В | В | В |  |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird bei Überlauf auf 1 gesetzt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein dezimaler Übertrag angefallen ist, sonst auf 0.
- X wie C.

# SUBQ Subtract Quick schnelle Subtraktion

Operation:

(Ziel)-<unmittelbare Daten>→Ziel

Assemblersyntax:

SUBI #<Daten>,<EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Subtraktion des unmittelbaren Datenelementes von dem Zieloperanden. Die Daten können die Werte 1 bis 8 annehmen. Die Wort- und Doppelwortoperationen können auch mit Adreßregistern durchgeführt werden, aber in diesem Fall werden die Bedingungscodes nicht gesetzt. Die Quelloperanden bei Wortoperationen werden vor der Befehlsausführung auf

32 Bits vorzeichenbehaftet erweitert.

#### Befehlsformat:



Effektive Adresse

Bezeichnungen:

Datenwert

- ist unmittelbar in 3 Bits co-

diert

0 - Subtraktion von 8.

 $1, \dots, 7$  - Subtraktion von 1

bis 7.

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - bestimmt den Zieloperanden.

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Register             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An Xi)         | 110   | Nummer des Registers |
| An               | 001   | Nummer des Registers | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | -                    |
| ~ (An)           | 100   | Nummer des Registers | d(PC, X)         | -     | -                    |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | -                    |

<sup>\*</sup> Nur Wort und Doppelwort

# Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Ergebnis 0 ist, sonst auf 0.
- V wird bei Uberlauf auf 1 gesetzt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein negativer Übertrag angefallen ist (Zieloperand ist kleiner als das Datenwort), sonst auf 0.
- X wie C.

# SUBX Subtract with Extend Subtraktion mit Frum Subtraktion mit Erweiterungsbit

(Ziel)-(Quelle)-X→Ziel Operation:

SUBX Dy, Dx Assemblersyntax:

oder

SUBX - (Ay), -(Ax)

Operandenlänge: Byte, Wort, Doppelwort

Beschreibung. Subtraktion des Quelloperanden und des Erweite-

> rungsbit von dem Zieloperanden und Überschreiben des Zieloperanden mit dem Ergebnis. Die Operan den können auf zwei verschiedene Arten angegeben werden: in Datenregistern und im Direkt-Modus mit

Predekrementierung.

#### Befehlsformat.

| 15 | 14 | 13 | 12 | 11 | 10           | 9  | 8 | 7           | 6             | 5 | 4 | 3   | 2 | 1           | 0  |
|----|----|----|----|----|--------------|----|---|-------------|---------------|---|---|-----|---|-------------|----|
| 1  | 0  | 0  | 1  | R  | egiste<br>Rx | er | 1 | Opera<br>mo | tions-<br>dus | 0 | 0 | R/M | R | egist<br>Ry | er |

Bezeichnungen:

Register Rx gibt das Zielregister an.

R/M=0 — Datenregister. R/M=1 - Adreßregister mit

Predekrementierung.

-00 - ByteOperationsmodus

01 - Wort

10 - Doppelwort

 gibt das Quellregister an. Register Ry

R/M=0 – Datenregister.

R/M=1 - Adreßregister mit

Predekrementierung

# Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
| В | В | В | В | В |

- N wird auf 1 gesetzt, wenn das Ergebnis negativ ist, sonst auf 0.
- Z wird auf 0 gesetzt, wenn das Ergebnis nicht 0 ist, sonst bleibt es unverändert.
- V wird bei Überlauf auf 1 gesetzt, sonst auf 0.
- C wird auf 1 gesetzt, wenn ein negativer Übertrag angefallen ist (Zieloperand ist kleiner als das Datenwort), sonst auf 0.
- X wie C.

Es ist notwendig, vor mehrfach genauen Operationen das Bit Z mit 1 zu initialisieren (siehe auch Programm 7 im Kapitel "Anwenderprogramm").

# SWAP Swap Register Halves Vertauschung von Por Vertauschung von Registerhälften

Operation:

Registerbits(31-16) Registerbits(15-0)

Assemblersyntax:

SWAP Dn

Operandenlänge.

Wort

Beschreibung:

Vertauschen der 16 unteren Bits mit den 16 oberen

Bits eines Registers.

#### Befehlsformat:

|   |   |   |   |   |   |   |   |   |   |   | 4 |   |   |       | _  |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|-------|----|--|
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | D | 0 | 0 | R | egist | 91 |  |

### Bezeichnungen:

Register

- gibt das Datenregister an, dessen Hälften miteinander vertauscht werden sollen.

# Bedingungscodes:

| X | N | Z | V | С |
|---|---|---|---|---|
|   | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit (Bit 31) des Ergebnisses 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das 32-Bit-Ergebnis 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt. C wird immer auf 0 gesetzt.
- X nicht beeinflußt.

# TAS\*

#### Test and Set Operand Test und Setzen von Operanden

Operation:

(Getestetes Ziel) -- Setzen CC

1→Bit 7 des Ziels

Assemblersyntax:

TAS < EA>

Operandenlänge:

Byte

Beschreibung:

Das durch die effektive Adresse angegebene Byte wird getestet, und gemäß dem Testergebnis werden

die Bedingungscodes N und Z gesetzt.

Das Bit 7 des Bytes wird auf 1 gesetzt. Dieser Befehl löst einen nicht unterbrechbaren Lese-/Änderungs-/ Schreibzyklus aus, der eine Synchronisation mehre-

rer Prozessoren ermöglicht.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4             | 3 | 2 | 1     | 0   |
|----|----|----|----|----|----|---|---|---|---|---|---------------|---|---|-------|-----|
| 0  | 1  | 0  | 0  | 1  | 0  | 1 | 0 | 1 | 1 | I | <b>/lo</b> du | S | R | egist | ter |
|    |    |    |    |    |    |   |   |   |   |   |               | _ | _ |       | -   |

Effektive Adresse

Bezeichnungen:

Effektive Adresse – gibt die Adresse des zu testenden Operanden an,

Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register              | Adressierungsart | Modus | Register             |
|------------------|-------|-----------------------|------------------|-------|----------------------|
| Ðn               | 000   | Nummer des Registers  | d(An, Xi)        | 110   | Nummer des Registers |
| Arı              | _     | -                     | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers. | Abs. L.          | 111   | 001                  |
| (An) +           | 011   | Nummer des Registers  | d(PC)            | -     | -                    |
| - (An)           | 100   | Nummer des Registers  | d(PC, Xi)        | -     | -                    |
| d(An)            | 101   | Nummer des Registers  | unmittelber      | -     | -                    |

# Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| - | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn das höchstwertige Bit des Bytes 1 ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn das Byte 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt.
  C wird immer auf 0 gesetzt.
  X nicht beeinflußt.

# TRAP

# Übergang in den Ausnahmezustand

Operation:

 $PC \rightarrow -(SSP)$  $SR \rightarrow -(SSP)$ (Vektor)→PC

Assemblersyntax: TRAP #<Vektor>

Operandenlänge:

Beschreibung:

Der Prozessor startet eine Ausnahmeprozedur. Die zugehörige Vektornummer wird durch 4 Bits innerhalb des Befehls angegeben. Es können also 16 verschiedene Vektoren für den TRAP-Befehl verwendet werden.

#### Befehlsformat:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2     | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|---|---|
| 0  | 1  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 1 | 0 | 0 |   | /ekto | r |   |

Bezeichnungen:

Vektor

- gibt dem Prozessor an, an welcher Adresse sich der in den PC zu ladende Wert befindet.

Bedingungscodes: nicht beeinflußt.

# TRAPV Trap and Overflow Übergang in den Ausnahmezustand bei Überlauf

Operation:

Wenn V=1, dann Übergang in den Ausnahmezu-

stand TRAPV.

Assemblersyntax:

TRAPV

Operandenlänge:

: -

Beschreibung:

Der Prozessor startet eine Ausnahmeprozedur für Überlauf, wenn das entsprechende Zustandsbit V=1 ist. Für die erzeugte Ausnahmebedingung ist die Vektornummer 7 zuständig. Wenn die Bedingung nicht erfüllt ist, wird in der normalen Befehlssequenz fortgefahren.

Befehlsformat:

| 15 | 14 |   | 12 |   |   | 9 |   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | O |
|----|----|---|----|---|---|---|---|---|---|---|---|---|---|---|---|
| 0  | 1  | 0 | 0  | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |

Bedingungscodes: nicht beeinflußt.

# **TST**

#### Test an Operand Test eines Operanden

Operation:

(Ziel)getestet→Setzen von CC

Assemblersyntax:

TST <EA>

Operandenlänge:

Byte, Wort, Doppelwort

Beschreibung:

Der Operand wird mit 0 verglichen. Die Bedingungscodes werden entsprechend dem Ergebnis gesetzt

Dabei erfolgt keine Wertanderung des Operanden.

## Befehlsformat.



### Bezeichnungen:

Operationsmodus - 00 - Byte

01 - Wort

10 - Doppelwort

Effektive Adresse - gibt die Länge des zu testen-

den Operanden an.

# Die folgenden Adressierungsarten sind zulässig:

| Adressierungsart | Modus | Register             | Adressierungsart | Modus | Reg ster             |
|------------------|-------|----------------------|------------------|-------|----------------------|
| Dn               | 000   | Nummer des Registers | d(An, XI)        | 110   | Nummer des Registers |
| An               |       | -                    | Abs W            | 111   | 000                  |
| (An)             | 010   | Nummer des Registers | Abs.L            | 111   | 901                  |
| (An) +           | 011   | Nummer des Registers | d(PC)            | -     | _                    |
| (An)             | 100   | Nummer des Registers | d(PC, Xi)        |       |                      |
| d(An)            | 101   | Nummer des Registers | unmittelbar      | -     | _                    |

Bedingungscodes:

| X | N | Z | V | C |
|---|---|---|---|---|
| _ | В | В | 0 | 0 |

- N wird auf 1 gesetzt, wenn der Operand negativ ist, sonst auf 0.
- Z wird auf 1 gesetzt, wenn der Operand 0 ist, sonst auf 0.
- V wird immer auf 0 gesetzt. C wird immer auf 0 gesetzt. X nicht beeinflußt.

#### UNLK Unlink Lösen

Operation:

An→SP

 $(SP)+\rightarrow An$ 

Assemblersyntax:

UNLK An

Operandenlänge:

: -

Beschreibung:

Der Inhalt des angegebenen Adreßregisters wird in den Stapelzeiger geladen. Anschließend wird das oberste Langwort des Stapels in das Adreßregister geladen (bei einer Stapelverwaltung von hohen zu niedrigen Adressen).

Befehlsformat:



Bezeichnungen:

Register

- gibt das Adreßregister an.

Bedingungscodes: nicht beeinflußt.

### DETAILLIERTE BETRACHTUNG EINZELNER BEFEHLE

#### **DER BEFEHL Bee**

Assemblersyntax: Bcc <Label>

#### Beschreibung:

Wenn die Bedingung erfüllt ist, wird die Programmausführung an der Adresse (PC)+Adreßdistanzwert fortgesetzt. Die Adresse wird dem Befehl selbst mitgegeben. Die Verschiebung wird ebenfalls unmittelbar im Befehlswort angegeben oder, wenn diese Bits 0 enthalten sind, ist sie in den 16 Bits des Erweiterungswortes enthalten.

Der Distanzwert wird automatisch auf 8 Bits gesetzt, wenn es sich bei dem Befehl um einen kurzen Verzweigungsbefehl handelt:

Bcc.Sxxx

Die Liste der möglichen Bedingungen ist in der Abb. 5.2 aufgeführt.

| 0100 | CC  | Carry Clear      | kein Übertrag            | C-0             |
|------|-----|------------------|--------------------------|-----------------|
| 0101 | CS  | Carry Set        | Übertrag                 | C = 1           |
| 0111 | EQ  | EQual            | gleich                   | Z = 1           |
| 0110 | NE  | Not Equal        | ungleich                 | Z = 0           |
| 1100 | *GE | Greater or Equal | größer oder gleich       | N + V = 0       |
| 1110 | *GT | Greater Than     | gróßer                   | Z + (N + V) = 0 |
| 0010 | HI  | Hlgh             | größer (ohne Vorzeichen) | C + Z = 0       |
| 1111 | *LE | Less or Equal    | kleiner oder gleich      | Z + (N + V) = 1 |
| 0011 | LS  | Less or Same     | kleiner oder gleich      | C + Z = 1       |
|      |     |                  | (ohne Vorzeichen)        |                 |
| 1101 | *LT | Less Than        | kle ner                  | N+V-1           |
| 1011 | ML  | Minus            | negativ                  | N = 1           |
| 1010 | PL  | Plus             | positiv                  | N-0             |
| 1000 | *VC | oVerflow Clear   | kein Überlauf            | V = 0           |
| 1001 | *VS | oVerflow Set     | Überlauf                 | V = 1           |
| 0000 | ●T  | True             | wahr                     | 1               |
| 0001 | •F  | False            | falsch                   | 0               |

- Bei Bcc nicht verwendet
- \* Benutzt im Zweierkomplement

Abb 5.2: Mögliche Bedingungen für Bcc

#### Beispiele:

#### BEQ SCHLEIFE BNE.S AUSGANG

Wenn das Programm mit einem Assembler für den 68000, wie er auf dem MOTOROLA-System EXORMACS vorhanden ist, umgewandelt wird und wenn die Erweiterung eines Befehls Bcc nicht angegeben wurde, werden folgende Maßnahmen automatisch getroffen: Falls das Label vor dem Aufruf definiert wird, wird der Befehl Bcc als Bcc.S assembliert, sofern dies möglich ist. Wurde das Label erst nach dem Aufruf definiert, wird der Befehl wie Bcc.L.behandelt. Dies wird durch das folgende Programm noch einmal verdeutlicht.

|                   | 00002000 |    | ORG   | \$2000 |
|-------------------|----------|----|-------|--------|
| 00002000          | 4E71     | L1 | NOP   |        |
| 00002002          | 67FC     |    | BEQ.S | L1     |
| 00002004          | 66FA     |    | BNE   | L1     |
| 00002006          | 6704     |    | BEQ.S | L2     |
| 00002008          | 66000002 |    | BNE   | L2     |
| WARNING 550       |          |    |       |        |
| 0000200C          | 4E71     | L2 | NOP   |        |
|                   |          |    | END   |        |
| <b>TOTAL ERRO</b> | RS       | 0  |       |        |
| TOTAL WARN        | IINGS    | 1  |       |        |

Bei diesem Beispiel fällt auf, daß der erste BNE-Befehl eine kurze Verzweigung ist, weil L1 schon zu Beginn des Programms definiert wurde. Der zweite BNE ist jedoch eine lange Verzweigung, denn L2 wird erst nach diesem Befehl definiert.

Die Warnung weist darauf hin, daß BNE eigentlich als kurzer Befehl hatte angegeben werden müssen.

|           | 0000200 | 0  | ORG   | \$2000 |
|-----------|---------|----|-------|--------|
| 00002000  | 4E71    | L1 | NOP   |        |
| 00002002  | 4E71    | L2 | NOP   |        |
| 00002004  | 67FA    |    | BEQ.S | L1     |
| 00002006  | 66F8    |    | BNE   | L1     |
| 00002008  | 67F8    |    | BEQ.S | L2     |
| 0000200A  | 66F6    |    | BNE   | L2     |
| END       |         |    |       |        |
| TOTAL ERF | 0       |    |       |        |
| TOTAL WA  | 0       |    |       |        |

Die zwei BNE sind kurze Verzweigungsbefehle, da L1 und L2 schon zu Beginn des Programms definiert wurden und der Distanzwert nicht größer als 8 Bits ist.

|             | 00002000 |    | ORG   | \$ 2000 |
|-------------|----------|----|-------|---------|
| 00002000    | 4E71     | L1 | NOP   |         |
| 00002002    | 4E71     | L2 | NOP   |         |
| 00002004    | 67FA     |    | BEQ.S | L1      |
| 00002006    | 6600FFF8 |    | BNE.L | L1      |
| WARNING 550 |          |    |       |         |
| 0000200A    | 67F6     |    | BEQ.S | L2      |
| 0000200C    | 6600FFF4 |    | BNE.L | L2      |
| WARNING 550 |          |    |       |         |
|             |          |    | END   |         |
| TOTAL ERROR | RS       | 0  |       |         |
| TOTAL WARN  | INGS     | 2  |       |         |

#### DER BEFEHL LEA

Assemblersyntax: LEA <EA>,An

## Beschreibung:

Die effektive Adresse wird in das angegebene Adreßregister geladen. Die 32 Bits dieses Adreßregisters werden durch den Befehl beeinflußt.

# Befehlsformat:



### Beispiel:

| 00001000  | 00001000<br>43F83000 | ORG<br>LEA<br>END | \$1000<br>\$3000, A1 |  |
|-----------|----------------------|-------------------|----------------------|--|
| TOTAL ERI | RORS 0               |                   |                      |  |
| TOTAL WA  | RNINGS 0             |                   |                      |  |

#### Programmlauf

| D0-D7 | 26534354 | 30303033 | 46495820 | 00000000 |
|-------|----------|----------|----------|----------|
|       | 20202020 | 20202020 | 00000000 | 00000061 |
| A0-A7 | 45533120 | 00003000 | 00000000 | 30303033 |
|       | 000012BD | 010E0DEA | 00000000 | 00000000 |

#### DER BEFEHL DBcc

Assemblersyntax: DBcc Dn, D16



#### Beschreibung:

Der Prozessor testet, ob die Bedingung erfüllt ist. Falls die Bedingung wahr ist, wird als Befehl ein NOP ausgeführt, und die Ausführung wird mit dem nachstfolgenden Befehl fortgesetzt. Ist die Bedingung falsch, dann wird das angegebene Datenregister Dn um 1 vermindert

- 1st das Ergebnis -1, wird dieser Befehl beendet, und es wird zum nächsten Befehl übergegangen
- Ist das Ergebnis nicht -1, führt der Prozessor den Befehl aus, der sich an der Adresse befindet, die durch den PC und den auf 32 Bit erweiterten Distanzwert festgelegt ist

# Befehlsformat:



Der prinzipielle Ablauf dieses Befehls wird durch das Flußdiagramm in der Abb. 5.3 dargestellt.



Abb. 5.3. Flußdiagramm des Befehls DBcc

Bemerkung: Dieser Befehl verändert die Bedingungscodes nicht. Falls die Bedingung F (False, Falsch) ist, akzeptieren die meisten Assembler den Mnemonik-Code DBRA anstelle von DBF.

### Beispiel für die Verwendung des Befehls DBcc:

Stellen wir uns einmal vor, daß wir einen Speicherbereich M1 in einen anderen Speicherbereich M2 kopiert haben. Wir wollen nun gerne überprüfen, ob sich bei der Übertragung kein Fehler eingeschlichen hat. Sobald eine Abweichung im Duplikat entdeckt wird, wird automatisch eine entsprechende Verarbeitung durchgeführt. In diesem Beispiel liegt aber der Schwerpunkt unseres Interesses nicht auf dieser Folgeverarbeitung. Wir nehmen ferner an, daß der Speicherbereich 10 Worte enthält. Für M1 verwenden wir einen Adreßzeiger A1. Der entsprechende Zeiger für M2 heißt A2. Unseren Schleifenzähler nennen wir D0.

Die Initialisierungsphase des Programms lautet folgendermaßen:

LEA \$2000, A1 LEA \$3000, A2 MOVEO #9. D0

;Laden von A1 mit \$2000 ;Laden von A2 mit \$3000

;Laden von D0 mit 9, da D0 von 9 bis -1;dekrementiert wird, was 10 Durchläufen ;entspricht.

Der Vergleich der beiden Speicherbereiche mit Postinkrementierung wird wie folgt realisiert:

Das zugehörige Flußdiagramm ist in Abb. 5.4 dargestellt.



Abb. 5.4: Flußdiagramm Vergleich von Speicherbereichen

Der Befehl für den Test auf Schleifenende lautet:

#### DBNE D0,SCHLEIFE

Solange Gleichheit zwischen (A1) und (A2) besteht und D0 ungleich -1

ist, wird der Befehl CMPM weiter ausgeführt. Das vollständige Programm sieht also folgendermaßen aus:

Die weiteren Befehle des Programms sind durch die Bemerkung "Folgebefehle" symbolisiert. Dies könnte z. B, ein Test sein, der feststellt, ob D0 gleich -1 ist. Falls dies der Fall ist, wäre das Ende des Speicherbe reichs erreicht. Während des Vergleichs der beiden Speicherbereiche auf Fehler kann nach einer entsprechenden Fehlererkennungsroutine zu einem zugehörigen Unterprogramm für die Fehlerbehandlung verzweigt werden.

In diesem Programm haben wir nun die Übereinstimmung von jeweils 10 Worten untersucht. Dies geschah unter der Kontrolle des Schleifenzählers D0, der mit 9 initialisiert wird, weil sich der DBNE-Befehl für die Schleifenüberwachung hinter dem Vergleichsbefehl CMPM befindet

Wir nehmen nun an, daß sich der Befehl CMPM nach dem Test von DBNE befände.

Während des ersten Schleifendurchlaufs ist der Zustand des Bedingungscodes Z noch nicht bekannt, und somit ist unklar, wie der Test DBNE ausgehen wird. Dennoch darf die Bedingung NE noch nicht als wahr bestätigt werden, bis der Befehl CMPM überhaupt einmal zur Ausführung gelangt. Es ist daher notwendig, Z mit 1 zu initialisieren. Dies wird durch folgenden Befehl erreicht:

ORI #4,CCR

Der Befehl CMPM wird nach dem Herunterzählen des Schleifenzählers D0 ausgeführt D0 muß daher mit 10 initialisiert werden, wenn

man den Vergleich für 10 Worte durchführen möchte. Für das Programm ergibt sich also:



Wir wollen nun ein anderes Beispiel betrachten, das die Bedeutung des Befehls DBF Dn,xxx (gleichbedeutend mit DBRA Dn,xxx) hervorhebt.



Abb 55. Prinzip des Kopierens

Dieser bedingte Verzweigungsbefehl führt einen Test auf Ende einer Verarbeitung durch.

Solange Dn ungleich -1 ist, beginnt die Verarbeitung wieder von neuem. Andernfalls wird sie beendet.

Gleichzeitig soll uns das Beispiel die Rolle der indizierten Adressierung mit Adreßdistanzwert vorführen.

Inhaltlich geht es darum, 8 Doppelworte aus einer Tabelle mit Verschiebung zu kopieren (Abb. 5.5).

Das Register A0 markiert den Anfang der Ursprungstabelle.

Das Register A1 markiert den Anfang der ersten Zieltabelle Die zweite befindet sich in einem relativen Abstand von 50 Bytes zu der ersten Zieltabelle

Das Register D0 dient als Indexregister, und D1 zählt die Schleifendurchgänge.

Das Programm kann also folgendermaßen aussehen:

| 00001000<br>00001000<br>00001008 | 00001000<br>41F82000<br>43F82050<br>7207 | ORG<br>LEA<br>LEA<br>MOVEO | \$1000<br>\$2000, A0<br>\$2050, A1<br>#7, D1 | ;Initialisierungen                                                               |
|----------------------------------|------------------------------------------|----------------------------|----------------------------------------------|----------------------------------------------------------------------------------|
| 0000100A                         | 4280                                     | CLR.L                      | D0                                           | ;Nullsetzen des<br>;Indexregisters                                               |
| 0000100C                         | SCHLEIF                                  | E                          |                                              |                                                                                  |
| 0000100C                         | 23B000000000                             | MOVE.L                     | (A0, D0), (A1,                               | D0)<br>;Übertragung zur<br>;ersten Tabelle                                       |
| 00001012                         | 23B0000000A                              | MOVE.L                     | (A0, D0), \$32 (                             | *                                                                                |
| 00001018                         | 5880                                     | ADDQ.L                     | #4, D0                                       | ;Aktualisieren des<br>;Indexregisters                                            |
| 0000101A                         | 51 <b>C9FFF</b> 0                        | DBRA                       | D1, SCHLEIFE                                 | , Wenn D1 ungleich<br>; 1 ist, erfolgt ein<br>;weiterer Schleifen-<br>;durchlauf |
|                                  |                                          | END                        |                                              |                                                                                  |

TOTAL ERRORS 0 TOTAL WARNINGS 0

#### DER BEFEHL EXT

Assemblersyntax: EXT.W Dn oder EXT.L Dn

#### Beschreibung:

Dieser Befehl erweitert das Vorzeichenbit des Datenregisters vom Byte zum Wort oder vom Wort zum Doppelwort. Wenn es sich also um eine Wortoperation handelt (.W), wird das Bit 7 des Registers Dn in die Bits 8 bis 15 kopiert Ist es hingegen eine Doppelwortoperation (.L), so wird das Bit 15 von Dn in die Bits 16 bis 31 kopiert.



Abb. 5.6 Erweiterung vom Byte zum Wort: W



Abb 5.7: Erweiterung vom Wort zum Doppelwort. L

#### DER BEFEHL SWAP

Assemblersyntax: SWAP Dn

### Beschreibung:

Dieser Befehl bewirkt einen Austausch der oberen 16 Bits mit den unteren 16 Bits in ein und demselben Datenregister (Abb. 5.8).



### Befehlsformat:



#### DIE BEFEHLE DIVS UND DIVU

Assemblersyntax: DIVS<E>,Dn, DIVU <EA>,Dn

(Ziel)/(Quelle)→Ziel

Diese Befehle führen eine Division des Zieloperanden durch den Quelloperanden durch.

Der Zieloperand besteht aus 32 Bits (Datenregister), der Quelloperand aus 16.

Das Ergebnis, das mit 32 Bits in den Zieloperanden geschrieben wird, ist folgendermaßen aufgebaut:

Der Quotient wird im niederwertigen Wort gespeichert.

- Der Rest wird im höherwertigen Wort abgelegt.



DIVS führt die Operation mit vorzeichenbehafteter Arithmetik durch, und das Vorzeichen des Restes ist das gleiche wie das des Dividenden (außer wenn es 0 ist).

DIVU führt die Operation ohne Vorzeichen durch. Eine Division durch 0 erzeugt den Ausnahmezustand "Division durch 0", dessen Vektornummer 5 ist.

Wenn im Verlauf der Befehlsausführung ein Überlauf auftritt, wird der Bedingungscode V auf 1 gesetzt, und die Operanden bleiben unverändert (der Zieloperand enthält nach wie vor den Dividenden).

#### Befehlsformat von DIVS:



#### Befehlsformat von DIVU:



Beispiel. Division mit oder ohne Überlauf

Das Prinzip der Division mit Kapazitätsüberlauf beruht auf der Tatsache, daß man jede 32-Bit-Zahl YZ (Y stellt die 16 höherwertigen und Z die 16 niederwertigen Bits dar) auch folgendermaßen schreiben kann:

Die Division wird also für jede Stelle durchgeführt, indem die Reste der vorhergehenden Divisionen berücksichtigt werden.

Der Rechenalgorithmus ist in Abb. 5.9 dargestellt.

Der Dividend YZ sei im Datenregister D1 und der Divisor X in D0 gespeichert. Nach Beendigung des Programmablaufs wird D1 den Quotienten und D0 den Rest enthalten.



Abb. 5.9: Flußdiagramm der Division

#### Das Programm sieht nun folgendermaßen aus:

| CLR.   | L D3       | ;Nullsetzen des Registers D3, das als      |
|--------|------------|--------------------------------------------|
| DIVU   | D0, D1     | ;temporärer Speicher benutzt wird<br>;YZ/X |
| BVC    | RESULT     | ,                                          |
|        |            | ;gestaltung verzweigt                      |
| MOV    | E.L D1, D2 | ;Retten von YZ in D2                       |
| CLR.   | W D1       | ;D1 wird von YZ auf Y 0 gesetzt            |
| SWA    | P D1       | ;D1 wird von Y 0 auf 0 Y gesetzt           |
| DIVU   | J D0, D1   | Y/Z = R1 Q1  in  D1                        |
| MOV    | E.W D1, D3 | ;Retten von R1 Q1 in D3                    |
| MOV    | E.W D2, D1 | ;D1 wird von R1 Q1 auf R1 Z gesetzt        |
| DIVU   | J D0, D1   | R1Z/X = R0Q0  in  D1                       |
| RESULT |            |                                            |
| MOV    | E.L D1, D0 | ;D0 = R Q oder besser R0 Q0                |
| SWA    | P D1       | ;D1 = Q R oder besser Q0 R0                |
| MOV    | E.W D3, D1 | D1 = Q 0 oder besser $Q0 Q1$               |
| SWA    | P D1       | D1 = 0 Q oder besser $Q1 Q0$               |
| CLR.   | W D0       | D0 = R0 oder besser $R00$                  |
| SWA    | P D0       | D0 = 0 R oder besser 0 R0                  |
| END    |            |                                            |

#### DER BEFEHL Sec

Assemblersyntax: Scc <EA>

# Beschreibung:

Die Bedingung cc wird geprüft Wenn sie erfüllt ist, wird das Byte, das durch die effektive Adresse bezeichnet ist, auf "Wahr" gesetzt, also auf den Wert \$FF. Andernfalls wird es auf "Falsch" gesetzt, also auf 0.

Dieser Befehl wird natürlich gebraucht, wenn man Boolesche Variablen setzen will.

# Be fehls format:



### Beispiel:

Setzen der Booleschen Variablen BGLEICH, wenn D0=D1 ist:

CLR.B BGLEICH; Nullsetzen des Booleschen Wertes; BGLEICH
CMP D0, D1; Vergleich der beiden Register SEQ BGLEICH; Setzen von BGLEICH
Folgebefehle

#### **BGLEICH**

DS.B 1 END

# DIE BEFEHLE FÜR DEZIMALARITHMETIK: ABCD, SBCD UND NBCD

Diese drei Befehle realisieren arithmetische Operationen mit mehrfacher Genauigkeit, und zwar mit binärcodierten Dezimalzahlen.

#### ABCD

Assemblersyntax: ABCD Dy, Dx oder ABCD -(Ay), -(Ax)

# Beschreibung:

Der Quelloperand wird zum Zieloperanden und dem Erweiterungsbit in binärcodierter Arithmetik addiert. Es handelt sich hierbei um eine Byteoperation.

$$(Quelle)_{10}+(Ziel)_{10}+X\rightarrow Ziel$$

Lediglich zwei Adressierungsarten sind zugelassen:

- direkte Datenregister-Adressierung
- indirekte Adressierung mit Predekrementierung

Besonders die zweite Adressierungsart ist in Zusammenhang mit diesem Befehlstyp interessant. Tatsächlich wird, wenn sich der Operand aus mehreren Bytes zusammensetzt, das höherwertige Byte an einer niedrigeren Adresse abgelegt als das niederwertige. Wenn also mit Predekrementierung gearbeitet wird, addiert man zuerst die unteren Bytes, dann die höheren usw. Das Ergebnis wird auf die gleiche Weise aufgebaut.

Sehen wir uns nun ein kleines Schema an: Dabei stellen X1, X2 und X3 die

Bytes dar, die die erste Zahl bilden, und Y1, Y2 und Y3 stellen die zweite Zahl dar, die jetzt addiert werden soll:

Vorgang im Speicher:



# Befehlsformat:



Rx: Nummer des Zielregisters Ry: Nummer des Quel registers

Wenn R/M=0, dann Adress erungsart Datenregister direkt Wenn R/M=1, dann Adress-erungsart indirekt mit Predekrementierung

Abb. 5 10: Format des Befehls ABCD

### Beispiel:



### Das Programm sieht folgendermaßen aus:

|          | 00001000 | UKG   | \$1000     |                                              |
|----------|----------|-------|------------|----------------------------------------------|
| 00001000 | 41F82008 | LEA   | \$2008, A0 | ;Initialisierung                             |
| 00001004 | 43F82018 | LEA   | \$2018, A1 | ;Initialisierung                             |
| 00001008 | 7002     | MOVEQ | \$2, D0    | ;Initialisierung des<br>;Schleifenzählers D0 |

:Schleifendurchlauf

 0000100A
 SCHLEIFE

 0000100A
 C308
 ABCD
 - (A0), (A1)
 ;BCD-Addition

 0000100C
 51C8FFF0
 DBRA
 D0, SCHLEIFE
 ;Wenn D0 ungleich - 1 ist,

 ;dann ein weiterer

**END** 

TOTAL ERRORS 0 TOTAL ERRORS 0

#### SBCD

Assemblersyntax. SBCD Dy, Dx oder SBCD - (Ay), - (Ax)

#### Beschreibung:

Der Quelloperand und das Erweiterungsbit werden vom Zieloperanden in binärcodierter Arithmetik subtrahiert.

Die erlaubten Adressierungsarten sind die gleichen wie im vorher beschriebenen Befehl ABCD.

$$(Ziel)_{10}$$
 (Quelle)<sub>10</sub> - X $\rightarrow$ Ziel

### Befehlsformat:



Register Rx: Bestimmt das Zielregister Register Ry: Bestimmt das Quellregister

Wenn R/M = 0, dann Adressierungsart Datenregister direkt Wenn R/M = 1, dann Adressierungsart indirekt mit Predekrementierung

Abb. 5.11: Format des Befehls SBCD

#### **NBCD**

Assemblersyntax: NBCD <EA>

### Beschreibung.

Der durch die effektive Adresse angesprochene Operand und das Erweiterungsbit werden in binärcodierter Arithmetik von 0 suhtrahiert. Wenn

das Erweiterungsbit 0 ist, wird also das Zehnerkomplement des Operanden gebildet. Ist es 1, so handelt es sich um das Neunerkomplement

#### Befehlsformat:



# DIE VERSCHIEBE- UND RINGVERSCHIEBUNGSBEFEHLE: ASR, ASL, LSR, LSL, ROXR, ROXL, ROR, ROL

Die Verschiebeoperationen werden durch die arithmetischen Befehle ASR (Rechtsverschiebung) und ASL (Linksverschiebung) und durch die logischen Befehle LSR (nach rechts) und LSL (nach links) ermöglicht.

Für die Ringverschiebung mit Hilfe des Erweiterungshits X werden die Befehle ROXR (nach rechts), ROXI. (nach links) zur Verfügung gestellt und ohne Erweiterungsbit die Befehle ROR (nach rechts) und ROL (nach links)

Die Arbeitsweise dieser verschiedenen Befehle wird mit Hilfe der schematischen Abb. 5.12 veranschaulicht.

Fur alle diese Befehle wird der Verschiebungsfaktor entweder direkt im Befehl (unmittelbar) oder über ein angegebenes Datenregister spezifiziert.

Hinweis: Wenn die Verschiebung oder Ringverschiebung ein Datenregister betrifft, kann der Operand ein Byte, ein Wort oder ein Doppelwort sein. Im Gegensatz dazu ist die einzig zulässige Operandenlänge für ein Speicherfeld die Wortlänge, wobei der maximale Verschiebungsfaktor ein Bit betragen darf.

Ferner beruht der Unterschied zwischen den logischen und der arithmetischen Verschiebung auf der Tatsache, daß das Bit V bei arithmetischen Befehlen gesetzt und bei logischen Verschiebungen gelöscht wird.



Abb. 5.12: Verschiebung und Ringverschiebung

Wenn mehrere Verschiebungen eines Speicherwortes durchgefuhrt werden sollen, gibt es zwei Möglichkeiten:

#### Erste Möglichkeit

```
N \text{ mal} \begin{cases} ROLA(0) & \text{ben\"otigt } 8+4Z \text{yklen} \\ ROLA(0) & \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot &
```

Die Ausführungszeit beträgt 12\*N Zyklen.

- Zweite Möglichkeit

```
MOVE (A0),D0; benötigt 8 Zyklen
ROL #$N,D0; benötigt 6+2*N Zyklen
MOVE D0,(A0); benötigt 8 Zyklen
```

Die Ausführungszeit beträgt 22+2\*N Zyklen.

Setzt man

dann ist für N>2.2 die zweite Methode die schnellere.

#### DER BEFEHL CHK

Assemblersyntax: CHK <EA>,Dn

Beschreibung:

Der Befehl CHK ermöglicht eine Überprüfung, ob der durch die effektive Adresse angegebene Wert einem Intervall #(0,(Dn)#) angehört. Ist der Wert kleiner als 0 oder größer als (Dn), so wird die Ausnahme CHK erzeugt (Vektornummer 6).

#### Befehlsformat:



#### Beispiel:

Wir wollen noch einmal das Beispielprogramm für den Befehl DBcc betrachten, das eine Fehlersuchroutine nach dem Kopieren eines Speicherbereichs in einen anderen darstellt. Nach dem Befehl DBNE wird der Wert von D0 überprüft und gemäß diesem Inhalt entschieden, ob die Kopie fehlerfrei ist oder nicht.

Das Programm sieht folgendermaßen aus:

Wenn alles in Ordnung ist und der Schleifenzähler D0 schließlich -1 beträgt, beginnt die Ausnahmeverarbeitung CHK, die beispielsweise eine Routine "Fehlerfreie Kopie" einleiten kann.

Wenn D0 von -1 verschieden ist, ist also ein Fehler aufgetreten, und der nächstfolgende Befehl in einer Befehlssequenz für die Fehlerbehandlung wird ausgeführt.

#### DER BEFEHL MOVEM

Assemblersyntax: MOVEM <Registerliste>,<EA> oder MOVEM <EA>,<Registerliste>

#### Beschreibung:

Die Registerliste wird von der oder zur angegebenen effektiven Adresse transportiert.

Ein Register wird dann transferiert, wenn das entsprechende Bit im Erweiterungswort gesetzt ist: Registermaske (wird vom Assembler eingerichtet).

Im Fall, daß ein Wort in ein Register übertragen wird, findet eine vorzeichenbehaftete Erweiterung des Wortes statt.

Wenn Register zu einem Speicherbereich transferiert werden sollen, sind folgende Adressierungsarten zugelassen:

- Adreßregister indirekt
- Adreßregister indirekt mit Predekrementierung
- Adreßregister indirekt mit Adreßdistanzwert
- Adreßregister indirekt mit Index
- absolute Adressierung

Für den umgekehrten Transport eines Speicherbereichs in Register gelten die folgenden Adressierungsarten:

- Adreßregister indirekt
- Adreßregister indirekt mit Postinkrementierung



Wenn DR = 0 → Übertragung von Registern in Speicherbereich Wenn DR = 1 → Übertragung von Speicherbereich in Register

Wenn SZ = 0 → Übertragung von Worten Wenn SZ = 1 → Übertragung von Doppelworten

Abb. 5.13: Format des Befehls MOVEM

- Adreßregister indirekt mit Adreßdistanzwert
- Adreßregister indirekt mit Index
- absolute Adressierung
- relative Adressierung
- relative Adressierung mit Index

Das Erweiterungswort mit der Registermaske folgt immer auf das Befehlswort.

### Adreßregister indirekt mit Predekrementierung

In diesem Modus ist nur die Registerubertragung zum Speicher gestattet. Der Inhalt der Register wird an der predekrementierten effektiven Adresse abgelegt und in Richtung der abfallenden Adressen gespeichert. Man überträgt zuerst die Adreßregister A7, A6, .., A0, danach die Datenregister D7, D6, ..., D0.

Entsprechend dem niederwertigsten Bit des Wortes, das das Maskenregi ster enthält, wird das erste Register übertragen Das höchstwertige Bit steht für das letzte zu übertragende Register.

Das Erweiterungswort hat also folgende Struktur:



# Beispiel:

Zu übertragende Register: D0, D4, A0, A1, A2, A3.

#### Befehlscode:



# Erweiterungswort:



#### Hexadezimalcode:

49A0 88F0

## Transfer-Reihenfolge:



## Adreßregister indirekt mit Postinkrementierung

In diesem Modus ist nur die Speicherfeldübertragung zu den Registern gestattet. In die Register wird der Inhalt der durch die effektive Adresse angegebenen Speicherstellen geladen. Danach wird die Adresse hochgezählt. Die Übertragungsreihenfolge in Richtung der Register ist folgende:



## Beispiel:

$$MOVEM(A5)+,A0-A4/D0-D7$$

Zu übertragende Register: A0, A1, A3, A4, D0-D7

#### Befehlscode:



## Erweiterungswort:

| 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

#### Hexadezimalcode:

4C9D 1FFF

## Transfer-Reihenfolge:



## Die anderen Adressierungsarten

Die Registerinhalte werden ab der angegebenen Stelle in aufsteigender Adreßfolge im Speicher abgelegt. Die Register selbst werden dann in der gleichen Reihenfolge ausgelesen wie bei der Adressierung mit Postinkre mentierung.



## Beispiel.

## MOVEM A0/D0/D1,\$3000

## Befehlscode:



## Erweiterungswort:

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|

## Hexadezimalcode:

48B8 0103 3000

## Transfer-Reihenfolge:



#### DER BEFEHL MOVEP

Assemblersyntax: MOVEP Dx,D(Ay) oder MOVEP D(Ay),Dx

#### Beschreibung:

Die Ubertragung findet zwischen dem Datenregister und den Bytes des Speichers mit abwechselnd geraden und ungeraden Adressen statt, und zwar beginnend mit der im Befehl angegebenen Adresse (Adreßregister indirekt mit Adreßdistanzwert).

Das obere Byte des Datenregisters wird zuerst übertragen, das untere zuletzt.

#### Beispiel:

Transfer eines Doppelwortes zum oder vom Speicher an einer geraden Adresse.

## Einteilung des Registers:

| 31 |    | 24 | 23 |    | 16 | 15 |    | 8 | 7  | 0 |
|----|----|----|----|----|----|----|----|---|----|---|
|    | X4 |    |    | Х3 |    |    | X2 |   | X1 |   |

## Einteilung des Speichers:



Transfer eines Wortes zum oder vom Speicher an einer ungeraden Adresse.

#### Einteilung des Registers:

| 31 | 24 | 23 | 16 | 15 8 | 3 7 | 7 ( | ) |
|----|----|----|----|------|-----|-----|---|
|    | •  |    |    | X 2  |     | X 1 |   |

## Einteilung des Speichers:



## Befehlsformat:



Der Modus gibt die Operationsrichtung und die -länge an-

Modus=100; Transfer eines Wortes vom Speicher zu einem Register.

Modus=101; Transfer eines Doppelwortes vom Speicher zu einem Register.

Modus=110; Transfer eines Registerwortes zum Speicher.

Modus=111; Transfer eines Registerwortes doppelter Länge zum Speicher.

Dem Befehlswort folgt unmittelbar das Wort, das den Verschiebungsfaktor enthält.

Dieser Befehl erlaubt auf einfache Weise, die Peripheriegerate zu programmieren, deren Registernummern aufeinanderfolgenden geraden oder ungeraden Adressen entsprechen.

Wir nehmen uns jetzt als einfaches Programmierbeispiel den peripheren Baustein PIA 6821 (Parallel Interface Adapter) vor.

Das Funktionsschema des 6821 ist in Abb. 5.14 dargestellt.



Abb. 5.14: Schematischer Aufbau des 6821

Die Abb. 5.15 verdeutlicht die interne Organisation des Bausteins.

Sechs interne Register des Bausteins 6821 sind von außen zugänglich:

- zwei Peripheriedatenregister PRA und PRB
- zwei Datenrichtungsregister DDRA und DDRB
- zwei Steuerregister CRA und CRB.



Abb. 5.15. Die interne Organisation des 6821

Die Leitungen der beiden Ports A und B können unabhängig als Ein- oder Ausgänge programmiert werden, in Abhängigkeit von den Datenrichtungsregister betrachtet werden. Eine 1 (bzw. eine 0) in einem der Bits des Registers programmiert die entsprechende Portleitung als Ausgang (bzw. als Eingang).

Die beiden Steuerregister CRA und CRB steuern die vier Leitungen CA1, CA2, CB1, CB2. Sie legen auch den Zugriff auf die Peripheriedatenregister und die Datenrichtungsregister fest.

Die interne Adreßstruktur und das Format der Befehlsworte sind aus den Tabellen der Abb. 5.16 und 5.17 ersichtlich.

|     |     | Bit in Befehis<br>register<br>CRA2 CRB2 |   | ausgewähltes Register      |
|-----|-----|-----------------------------------------|---|----------------------------|
| RS1 | RS0 |                                         |   |                            |
| 0   | 0   | 1                                       | х | Peripheres Datenregister A |
| 0   | 0   | 0                                       | х | Datenrichtungsregister A   |
| 0   | 1   | l x                                     | х | Steuerregister A           |
| 1   | 0   | х                                       | 1 | Peripheres Datenregister B |
| 1   | 0   | x                                       | 0 | Datenrichtungsregister B   |
| 1   | 1   | х                                       | x | Steuerregister B           |

x = ohne Bedeutung

Abb 5 16. Interne Adressierung

|     | 7     | 6     | 5 | 4                    | 3 | 2                                    | 1                    | 0 |  |
|-----|-------|-------|---|----------------------|---|--------------------------------------|----------------------|---|--|
| CRA | IRQA1 | IRQA2 |   | Befehl<br>von<br>CA2 |   | Zugriff Befeh<br>auf von<br>DDRA CA1 |                      |   |  |
|     | 7 6   |       | 5 | 4                    | 3 | 2                                    | 1                    | 0 |  |
| CRB | IRQB1 | 1RQ82 |   | Befehl<br>von<br>CB2 |   |                                      | Befehl<br>von<br>CB1 |   |  |

Abb 5 17: Format der Befehlsworte

Wir wollen die Programmierung dieses Bausteins vereinfachen, indem wir folgendermaßen initialisieren:

- Port A
  - die 4 unteren Bits als Ausgang
  - die 4 oberen Bits als Eingang
- Port B
  - alle 8 Bits als Ausgang

Unterbrechungssteuerung nicht aktiv. Zugriff zu Datenregistern PRA, PRB

Die Adressen der Register sind:

ADA: DDRA/PRA: \$1001 ADB: DDRB/PRB: \$1003

ADRA: CRA: \$1005 ADRB: CRB: \$1007

Eine Moglichkeit, den Baustein zu programmieren, 1st nun die folgende:

ADA EQU \$1001 ADB EQU ADA + 2

| ADRA | EQU    | ADA + 4      |
|------|--------|--------------|
| ADRB | EQU    | ADA + 6      |
|      | MOVE.B | # \$0F, ADA  |
|      | MOVE.B | # \$FF, ADB  |
|      | MOVE.B | # \$04, ADRA |
|      | MOVE.B | # \$04, ADRB |

Die zweite Möglichkeit ergibt sich aus der Verwendung des MOVEP-Befehls:

| ADA | EQU     | \$1001            |
|-----|---------|-------------------|
|     | LEA     | ADA, A0           |
|     | MOVE.L  | # \$0FFF04404, D0 |
|     | MOVEP.L | D0, 0(A0)         |

Mit dieser Programmierungsmethode kann man gleichzeitig N Peripheriebausteine initialisieren, wenn die Initialisierungswerte so im Speicher abgelegt sind, wie es die Abb. 5.18 zeigt



Abb. 5.18. Immalisierung von N Peripheriebausteinen

## Das Programm sieht so aus:

|          | MOVEQ       | # N,D1       | ;D1 enthält die Anzahl des<br>;zu initialisierenden                                                                                                                                |
|----------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | LEA         | ADPER1, A0   | ;Peripheriebausteins<br>;A0 enthält die Adresse<br>;des ersten Peripherie-                                                                                                         |
|          | LEA         | TABLE, A1    | ;bausteins<br>;A1 enthalt die Startadresse<br>;der Tabelle                                                                                                                         |
|          | BRA         | INIT         | ;D0 wird von N auf -1 her-                                                                                                                                                         |
| SCHLEIFE | MOVE.L      | (A1)+,D0     | ;untergezählt. Dies ermög- ;licht die Initialisierung von ;N Peripheriebausteinen ;Initialisierungswert in (D0) ;schreiben und AI erhöhen, ;so daß es auf das folgende ;Wort zeigt |
|          | MOVEP.L     | D0,0(A0)     | ;Übertragung zum Periphe-<br>;riebaustein                                                                                                                                          |
|          | ADD.L       | # 8, A0      | ;Setzen von A0 auf den<br>;nächsten zu initialisieren-<br>;den Peripheriebaustein                                                                                                  |
| INIT     | DBRA<br>END | D0, SCHLEIFE | ;nächste Initialisierung                                                                                                                                                           |

## **DER BEFEHL PEA**

Assemblersyntax: PEA <EA>

## Beschreibung:

Die effektive Adresse wird berechnet und auf den Stapel gelegt. Der Operand ist 32 Bits lang.

## Befehlsformat:



#### Beispiel:

LEA \$2000,A0 LEA \$1000,SP PEA -6(A0) END

## Ausführung:

Die Adresse \$1FFA (also \$2000 6) ist die effektive Adresse und wird ab der Adresse \$0FFC auf den Stapel gelegt.



#### DER BEFEHL TAS

Assemblersyntax: TAS < EA>

## Beschreibung:

Der Operand, der Bytelänge hat, wird getestet, bevor N und Z entsprechend gesetzt werden.

Das höchstwertige Bit des Bytes wird immer auf 1 gesetzt.

Dieser Befehl löst einen Lese-/Änderungs-/Schreibvorgang aus, der nicht unterbrechbar ist.

## Befehlsformat:



Dieser Befehl gewinnt seine Bedeutung in Multiprozessor-Systemen.

Bei diesen Systemen haben stets verschiedene Prozessoren Zugriff zu gemeinsamen Ressourcen. Diese Ressourcen können Arbeitsspeicher oder Peripheriebausteine sein

Zwei Beispiele für Multiprozessor-Systeme sind in Abb. 5.19 und 5.20 gezeigt.



Abb. 5.19. Zweiphasiges Multiprozessor-System mit Speicherverbindung

In der ersten Konfiguration arbeiten die Prozessoren taktverschieden, und es können auch nicht mehr als zwei sein. Das Multi-Bus-System eröffnet die Möglichkeit, zwei oder auch mehr Prozessoren miteinander zu verbinden.

Bei der zweiten Konfiguration könnte man sich beispielsweise ein Verbindungsschema zwischen dem Mikroprozessor 68000 und dem IPC 68120/21

(Intelligent Peripheral Controller), einem universellen, intelligenten Peripherie-Steuerbaustein, für die Aufnahme und Verarbeitung analoger Daten vorstellen (Abb. 5.21).



Abb. 5.20: Multiprozessor-System mit Multi-Bus-Technik

Der MC68120 ist ein Mikroprozessor, der die nötige Hardware mitbringt, um mehrere Prozessoren in einem System zu verkoppeln.

Dazu gehören vor allen Dingen ein RAM mit Doppelzugriff und Semaphore Register (Eine Semaphore ist ein Kennzeichen, das anzeigt, ob ein bestimmtes gemeinsam benutztes Gerät frei ist oder nicht.) Das RAM mit Doppelzugriff gewinnt seine Bedeutung hauptsächlich durch Übertragung zwischen den Systembausteinen und dem Peripherie-Steuerbaustein, damit die lokalen Schaltungen nicht gestört werden.

Die sechs Semaphore-Register werden benutzt, um die Datenzugriffskontrolle zwischen dem Systembus und den lokalen Bussen zu regeln. Es wird auf diese Weise eine Zusammenarbeit der verschiedenen Prozessoren geregelt, bei der keine Synchronisierungsprobleme auftreten.

Das Semaphore-Register ist ein 8-Bit-Register, dessen höchstwertiges Bit man "Semaphore-Bit" nennt Es ist dasjenige, das die Aktivität der jeweiligen Einheit meldet.

Ist das Bit 0, so steht die Einheit zur Verfügung.
 Ist das Bit 1, so wird die Einheit bereits anderweitig benutzt.



Abh. 5.21: Verhindung zwischen einem MC68000- und drei MC68120-Bausteinen (schematisch)

In einigen Semaphore-Registern wird das Bit 6 (ownership) nur beim Lesen verwendet, und es gibt an, welcher Prozessor das Semaphore-Bit gesetzt hat.

Wenn das Semaphore-Bit aktiv ist, gibt das Bit 6 an, welcher Prozessor es gesetzt hat.

Wenn das Semaphore-Bit 0 ist, gibt Bit 6 den letzten Prozessor an, der es gesetzt hatte.

Der TAS-Befehl gestattet das Abfragen und Setzen des Semaphore-Bits.

Das Ablaufdiagramm in Abb. 5.22 zeigt den Fall, daß verschiedene Prozessoren den Zugriff zu einem gemeinsamen Speicherbereich, der aus mehreren Blöcken besteht, wünschen.



Abb. 5.22: Beispiel für die Verwendung des TAS-Befehls

Es ist notwendig, daß der TAS-Befehl in einem nicht unterbrechbaren Zyklus abgewickelt wird, damit ein Fall, wie er in Abb. 5.23 aufgezeigt wird, nicht eintreten kann.



Abb. 5.23: Zwei Prozessoren arbeiten mu demselben Betriebsmittel

# DIE BEFEHLE FÜR BITMANIPULATIONEN: BTST, BSET, BCLR, BCHG

#### BTST

Assemblersyntax: BTST Dn, <EA> oder BTST #xxx, <EA>

## Beschreibung:

Ein Bit des Zieloperanden wird getestet. Das Ergebnis dieses Tests wird im Bit Z sichtbar gemacht.

Die Nummer des zu testenden Bits wird entweder unmittelbar oder in einem Datenregister angegeben.

Wenn die effektive Adresse ein Datenregister ist, kann man die Bits 0, 1, ..., 31 testen.

Im Gegensatz dazu können bei einem Speicherbereich nur jeweils die Bits 0 bis 7 getestet werden.



Die vier Befehle können, wie in Abb. 5.24 dargestellt, schematisiert werden.

## Flußdiagramm für BTST



## Flußdiagramm für BSET



Abb. 5.24: Befehle zum Testen eines Bits



Abh. 5.24: Befehle zum Testen eines Bits (Forts.)

nächster Befehl

## Beispiel:

| Wir | haben | die | fol | lgenden | Befehle: |
|-----|-------|-----|-----|---------|----------|
|-----|-------|-----|-----|---------|----------|

| 00001000<br>00001004            | 00001000<br>303C00FE<br>08000000 | ORG<br>MOVE.W<br>BTST | \$1000<br>#\$00FE, D0<br>#0, D0 |
|---------------------------------|----------------------------------|-----------------------|---------------------------------|
| TOTAL ERRORS 0 TOTAL WARNINGS 0 |                                  | END                   |                                 |

## Der Programmlauf ergibt:

| D0-D7         | 265300FE  | 30303033 | 46495820 | 00000000 |
|---------------|-----------|----------|----------|----------|
| 20 67         | 20202020  | 20202020 | 00000000 | 00000000 |
| A0-A7         | 45322020  | 434E3130 | 00000000 | 30303033 |
|               | 000012BD  | 01A0D104 | 00000000 | 00000000 |
| PC = 00001004 | SR = 8000 | BTST     | #0, D0   |          |
| D0-D7         | 265300FE  | 30303033 | 46495820 | 00000000 |
|               | 20202020  | 20202020 | 00000000 | 00000061 |
| A0 A7         | 45322020  | 434E3130 | 00000000 | 30303033 |
|               | 000012BD  | 01A0D104 | 00000000 | 00000000 |
| PC = 00001008 | SR = 8004 |          |          |          |

#### DER BEFEHL LINK

Assemblersyntax: LINK An, #<Adreßdistanzwert D>

## Beschreibung:

Der Befehl veranlaßt drei unterschiedliche Aktionen:

- 1. Der Wert des Adreßregisters wird auf den Stapel an der Adresse abgelegt, die durch den Stapelzeiger SP angegeben wird.
- 2. Das Adreßregister wird mit dem Inhalt des Stapelzeigers gefullt.
- Der Adreßdistanzwert wird auf 32 Bits erweitert und zum Inhalt des Stapelzeigers addiert.

$$An \rightarrow -(SP)$$
  
 $SP \rightarrow An$   
 $SP + D \rightarrow SP$ 

Das Adreßregister An wird auch Rahmenzeiger (RZ) oder Frame Pointer (FP) (auch Speicherbereichszeiger) genannt. Register, die diese Funktion wahrnehmen können, sind die Register A0, A1, ..., A6.

Der Adreßdistanzwert oder Verschiebungsfaktor ist ein 16-Bit-Datenwert:

$$-32768 \leqslant D \leqslant +32767$$
Nummer des Registers
15
O 1 0 0 1 1 1 0 0 1 0 1 0
Adreßdistanzwert

Die drei Ubertragungen, die durch den LINK-Befehl ausgelöst werden, sind die folgenden:

An -- (SP): Daten oder Variablen des FP werden auf den Stapel

gebracht.

SP→An : Stapelzeiger wird in den FP gelden.

SP+D-SP: Verschiebungswert wird zum SP addiert.

Wir machen uns diesen Vorgang noch einmal anhand der Abb. 5.25 klar.



Abb. 5.25: Die Arbeitsweise des LINK-Befehls

## 1. Aktion



## 2. Aktion



Abb 5 25: Die Arbeitsweise des LINK-Befehls (Forts )

#### 3. Aktion



Abb. 5 26: Die Arbeitsweise des LINK Besehls (Forts)

#### DER BEFEHL UNLK

Assemblersyntax: UNLK An

Beschreibung.

Der Inhalt des angegebenen Adreßregisters wird zum Stapelzeiger transferiert. Daraufhin wird der Inhalt des Speicherbereichs, der durch den Stapelzeiger adressiert ist, in das Adreßregister übertragen

$$An \rightarrow SP$$
  
(SP) $\rightarrow An$ 

Das Register An fungiert hier wieder als Rahmenzeiger (Frame Pointer).

## Befehlsformat:



UNLK bewirkt genau das Gegenteil von LINK. Der Speicherbereich wird wieder freigegeben und der Rahmenzeiger wiederhergestellt. Wir wollen uns noch einmal den Zustand des Stapels nach Beendigung des LINK-Befehls vor Augen führen, um den Vorgang beim Befehl UNLK näher zu untersuchen (Abb. 5.26).

## ursprünglicher Zustand (vor UNLK, nach LINK)



Abb 5 26: Die Arbeitsweise des UNLK-Befehls



Abb. 5.26. Die Arbeitsweise des UNLK-Befehls (Forts.)

#### LINK UND UNLK

LINK und UNLK sind zwei sehr anspruchsvolle Befehle, die es ermöglichen, auf hohem Sprachniveau zu arbeiten, und die auch sehr gut Sprachen wie zum Beispiel Pascal unterstützen. Dieser Sprachtyp kennt den Begriff der Prozeduren (Unterprogramme), die dem Blockkonzept moderner Sprachen entsprechen und mit lokalen Daten arbeiten. Prozeduren verarbeiten prinzipiell zwei Sorten von Variablen:

- lokale Variablen, die nur innerhalb der Prozedur deklariert und bekannt sind,
- globale Variablen, die außerhalb des Prozedurblocks deklariert sind und in ihm und im übergeordneten Programm bekannt sind (Abb. 5.27).



Abb. 5.27. Prozedurbegriff

Zum Beispiel sind die Variablen a1, a2, ... als lokale Variablen für die Prozedur A und global für die Prozeduren B und C anzusehen.

Wenn das Hauptprogramm die Prozedur A aufruft, die ihrerseits B und dann C aufruft, ergibt sich, daß die lokalen Variablen zum Zeitpunkt der Prozedureröffnung eingerichtet werden mussen und daß sie sofort nach dem Verlassen der Prozedur wieder freigegeben werden

Durch Nutzung eines Stapelspeichers für das Ablegen der lokalen Daten der momentan bearbeiteten Prozedur kann auf einfache Weise ein Uber gang von einer Variablenumgebung zu einer anderen verwirklicht werden (Abb. 5.28).



Abb 5.28: Zustandsfolge des Stapelspeichers für sukzessive Unterprogrammaufrufe

Diese Prozedur-orientierte Programmabwicklung wird durch einen Speicherbereichszeiger unterstützt, der jeweils den Variablen einer Prozedur zugeordnet wird und der bei jedem Aufruf einer weiteren Prozedur gerettet werden muß (Abb. 5.29).



Abh. 5.29: Bedeutung des Speicherbereichszeigers

Diese Verkettung der Speicherbereichsadressen gestattet bei der Rückkehr aus untergeordneten Routinen zu aufrufenden Prozeduren eine entsprechende Wiederentnahme der zugehörigen Felder vom Stapel. Es ist ferner ersichtlich, daß die Variablen der zuletzt aufgerufenen Prozedur nicht zugleich mit deren Wiederverlassen schon explizit gelöscht werden. Sie müssen jedoch aufgrund der damit verbundenen Speicherfreigabe als verloren angesehen werden.

Die Befehle LINK und UNLK stellen automatisch die Adressierung der lokalen Daten und Parameter sicher.

Der Befehl LINK kennt zwei verschiedene Parameter:

- das Adreßregister
- die unmittelbare Konstante

Das Adreßregister hat die Aufgabenstellung eines Datenbereichszeigers (FP).

Die Konstante gibt die im Stapel zu speichernde Byteanzahl an.

Der Stapelzeiger wird so gesetzt, daß ein entsprechender Freibereich geschaffen wird. Ferner wird der vorhergehende Wert des Adreßregisters FP wiederhergestellt.

UNLK kehrt den ganzen Vorgang dadurch wieder um, daß Speicherraum freigegeben wird und der alte Inhalt des Zeigers wiederhergestellt wird

Auf diese Weise sorgt ein LINK-Befehl bei Unterprogrammbegum für das Laden der Daten in den zugehörigen Speicherbereich und ermöglicht ihre Adressierung mittels des Rahmenzeigers FP.

Ein entsprechender UNLK-Befehl bei Unterprogrammende stellt den alten Stapelzustand vor dem Aufruf wieder her und holt den alten Wert des Speicherbereichszeigers wieder zurück. Diese beiden Befehle gestatten also problemlos, ineinander verschachtelte Unterprogrammaufrufe zu realisieren.

Es ist ebenfalls möglich, rekursive Prozeduraufrufe zu programmieren, da bei jedem erneuten Prozeduraufruf jeweils ein neuer zugehöriger Satz mit lokalen Variablen zur Verfügung gestellt wird

Übersetzung eines Pascal-Programms in 68000-Assembler:

VAR PARAM1, PARAM2: INTEGER; PROCEDURE PROC (X: INTEGER; VAR Y: INTEGER); VAR A, B: INTEGER; BEGIN
<Abarbeitung der Prozedur>
END;
BEGIN
PROC (PARAM1, PARAM2)
END;

#### Dies führt zu:

|      | MOVE                                           | PARAM1 in → - (SP)              | ;Retten von PARAM1 auf        |
|------|------------------------------------------------|---------------------------------|-------------------------------|
|      |                                                |                                 | ;den Stapel                   |
|      | PEA                                            | PARAM2                          | ;Retten der Adresse von       |
|      |                                                |                                 | ;PARAM2                       |
|      | JSR                                            | PROC                            | ;Aufruf von PROC              |
|      | ADD                                            | # 6 zu SP                       | ;Setzen des Stapelzeigers auf |
|      |                                                |                                 | ;die ursprüngliche Position   |
| PROC |                                                |                                 | ,                             |
|      | LINK                                           | FP.4                            | ;Link-Operation               |
|      | MOVEM                                          | <registerliste></registerliste> | $in \rightarrow -(SP)$        |
|      |                                                | 0                               | ;Retten der Register zu       |
|      |                                                |                                 | ;Beginn des Unterprogramms    |
|      | <abarbeitung der="" prozedur=""></abarbeitung> |                                 | ,                             |
|      |                                                | <registerliste></registerliste> | von (SP) +                    |
|      |                                                | U                               | ;Wiederherstellung der Re-    |
|      |                                                |                                 | gister vor dem Rücksprung     |
|      | UNLK                                           | FP                              | , <del>,</del>                |
|      | RTS                                            |                                 |                               |

Die Verwaltung des Stapels wird durch Abb. 5 30 verdeutlicht.



Abb. 5.30: Stapelverwaltung (Umwandlung des Pascal Programms in Assembler)





## Aufruf der Prozedur PROC



# Ausführung von LINK



Abb 5.30 Stapelverwaltung (Umwandlung des Pascal-Programms in Assembler) (Forts.)



Ausführung des Befehls MOVEM ... von (SP) + nach der Abarbeitung der Prozedur



Abb 5 30. Stapelverwaltung (Umwandlung des Pascal-Programms in Assembler) (Forts.)



Abb 5 30: Stapelverwaltung (Umwandlung des Pascal-Programms in Assembler, (Forts.)

Beispiel für die Verwendung von LINK und UNLK in einem Programm:

| 3000        | LEA  | \$2000, A6 |
|-------------|------|------------|
| 3004        | LEA  | \$1FF0, SP |
| 3008 PPROCA |      |            |
| 3008        | NOP  |            |
| 300A        | NOP  |            |
| 300C        | NOP  |            |
| 300E        | PEA  | -6(A6)     |
| 3012        | JSR  | PROCB      |
| 3016        | LEA  | 4 (SP), SP |
| 301A        | NOP  | , ,        |
| 301C        | NOP  |            |
| 301E        | NOP  |            |
| 3020        | ENDA |            |
| 3022 PROCB  |      |            |
| 3022        | LINK | A6, -\$10  |
| 3026        | NOP  |            |
| 3028        | NOP  |            |
| 302A        | NOP  |            |
| 302C        | UNLK | Аб         |
| 302E        | RTS  |            |
|             | END  |            |
|             |      |            |

Die Verwaltung des Stapels wird durch Abb. 5 31 verdeutlicht.

#### LINK-Aktion

LINK: A6 → -(SP) Aktion 1 SP → A6 Aktion 2 SP + d → SP Aktion 3



Abb. 5.31: Arbeitsweise von LINK und UNLK

## **UNLK-Aktion**

UNLK: A6 -- (SP) Aktion 1 (SP) -- A6 Aktion 2



Abb. 5.31: Arbeitsweise von LINK und UNLK (Forts.)

## Übungen

- 5.1: Wie lang ist der Adreßdistanzwert bei den Befehlen Bcc? Wo befindet er sich in bezug auf den Operationscode?
- **5.2:** Wie oft kann D0 beim Befehl DBcc D0,D16 mit (D0)=6 herunterge zählt werden?
- **5.3:** Welches Bit des Bedingungscoderegisters wird bei Vergleichsbefehlen nicht beeinflußt?
- 5.4: Was bewirkt der Befehl EXT W D0, wenn D0=\$FFEE3210 ist?
- 5.5: Welche Zieloperanden sind bei den Befehlen DIVS und DIVU möglich?
- **5.6:** Das folgende Programm ruft einen Ausnahmezustand hervor. Welchen und warum?

DBEQ D0, SCHLEIFE

**5.7:** Welche Befehle in der folgenden Befehlssequenz sind falsch und warum?

ROL.B #4,D1 ROXL.L D1,D0 LSL #3,(A1) ASR.W D0, D1 ALS.B (A0) LSR L #3,(A1)

## Lösungen

- **5.1:** Der Adreßdistanzwert ist 8 Bits lang und befindet sich im Befehlswort selbst, oder er ist 16 Bits lang und ist im Erweiterungswort enthalten.
- **5.2:** D0 kann von 6 bis -1, also 7mal heruntergezählt werden.
- 5.3: Nur das Bit X wird nicht beeinflußt.
- 5.4: Nach der Ausführung des Befehls ist D0=\$FFEE0010.

- 5.5: Der Zieloperand kann nur ein Datenregister sein.
- 5.6: Der Ausnahmezustand wird durch eine illegale Adresse hervorgerufen, denn D0 spielt die Rolle des Schleifenzählers und Indexregisters, so daß D0 beim zweiten Schleifendurchgang den Wert 3 hat, und man muß auf eine ungerade Adresse zugreifen.

Richtig wäre das folgende Beispiel:

#### 5.7:

| ROL.B | #4, D1  | ;korrekt                                                              |
|-------|---------|-----------------------------------------------------------------------|
| ROXLL | D1, D0  | ;korrekt                                                              |
| LSL   | #3,(A1) | ;bei Speicherfeldern ist nur                                          |
|       |         | eine Verschiebung um 1 Bit möglich                                    |
| ASR.W | D0, D1  | ;korrekt                                                              |
| ASL.B | (A0)    | ;bei einem Speicherfeld muß der Operand<br>;ein Wort sein             |
| LSR.L | #3,(A1) | ;3 und .L sind nicht korrekt, da ein<br>;Speicherfeld verschoben wird |
|       |         |                                                                       |

# Kapitel 6

# Anwenderprogramme

#### PROGRAMM 1

### Funktionsbereich des Bits X:

Das Bit X wird nicht bei allen Befehlen beeinflußt. Das bietet dem Anwender vielfältige Möglichkeiten.

Wird beispielsweise eine Rechnung mit mehrfacher Genauigkeit durchgeführt, bei der ein Ubertrag zugespeichert wird, ist es möglich die Bedingungscodes zu verändern, insbesondere den für den Ubertrag C, ohne das Bit X zu beeinflussen.

Wir wollen nun eine Reihe Worte addieren. Die erste Reihe ist über Register A0, die zweite über A1 adressierbar Beide enthalten gleich viele Elemente, und das Register A2 enthält die Endadresse der Reihe.

| SCHLEIFE | AND   | #\$EF,CCR    | ;Bit X auf 1 setzen                                                                      |
|----------|-------|--------------|------------------------------------------------------------------------------------------|
|          |       | -(A0), -(A1) | ;Addition zweier Worte mit X ;Wenn ein Übertrag entsteht,                                |
|          | CMP.L | A2, A1       | ;werden C und X gesetzt<br>;Test auf Ende der Liste.<br>;Dieser Befehl kann C ver-       |
|          | BLS   | SCHLEIFE     | ;ändern, aber nicht X.<br>;Wenn das Ende der Liste noch<br>;nicht erreicht ist, wird die |
|          | END   |              | ;Schleife erneut durchlaufen                                                             |

#### PROGRAMM 2

Es soll eine Tabelle von 256 Bytes, die in Doppelworten eingeteilt ist, auf 0 gesetzt werden. Die Startadresse ist MEM (Abb. 6.1).



Abb. 6.1: Speicherorganisation (Programm 2)

Das zugehörige Flußdiagramm ist in Abb. 6.2 zu sehen.



Abb. 6.2: Flußdiagamm (Programm 2)

Das Programm sieht nun folgendermaßen aus:

LEA MEM, A0 ;Laden von MEM in A0 MOVE.W #(\$100 / 4) - 1, D0 ;Laden des Zählers D0 mit

;dem Wert 63

LOESCH

CLR.L (A0) + ;Nullsetzen des durch A0 ;adressierten Doppelwortes

;und Erhöhung von A0 um 4

DBRA D0, LOESCH ;Dekrementieren von D0.

;Wenn D0 ungleich -1 ist, geht ;es zurück zu RAZ, wenn D0 ;gleich -1 ist, dann ist das

:Ende erreicht

**END** 

## **PROGRAMM 3**

In den folgenden drei Beispielen wird ein Speicherbereich auf 0 gesetzt, der durch A0 und A1 begrenzt ist (A1>=A0).

- 1. Fall: Für A0 und A1 werden keine Bedingungen gestellt.
- 2. Fall: A0 und A1 enthalten gerade Adressen.
- 3. Fall: A0 und A1 enthalten gerade Adressen, die durch 4 teilbar sind.

# Programm zum 1. Fall:

CLR.B D0 ;D0 = xxxxxx00

SCHLEIFE

MOVE.B D0, (A0) + ;(A0) = 00 und Inkrementie-;rung von A0

CMPA.L A0, A1 ;Test auf Ende des Speicher-;feldes

BPL SCHLEIFE ;Solange A0 < A1 ist, wird die ;Schleife durchlaufen

# Programm zum 2. Fall:

**END** 

CLR W D0 SCHLEIFE MOVE.W D0, (A0) +

# Programm zum 3. Fall:

**SCHLEIFE** 

CLR.L (A0) + CMPA.L A1, A0 BPL SCHLEIFE END

#### PROGRAMM 4

Die Addition von 10 Datenworten soll realisiert werden:

Wort 
$$0 + Wort 1 + ... + Wort 9$$

Im Speicher soll es folgendermaßen aussehen:



Das Ergebnis soll in Register D0 abgelegt werden, während das Adreßregister A0 auf das erste zu addierende Wort zeigt. Es müssen Zahlen mit und ohne Vorzeichen berücksichtigt werden.

# Zahlen ohne Vorzeichen:

| -16 | *        |    |
|-----|----------|----|
| -   | Lösuns   | 2. |
| 4 . | LIVJU/65 | ς, |

**START** 

| CLR.L<br>CLR.L<br>MOVE.L | D0<br>D1<br>#\$9, D2 | ;D0 = 00000000<br>;D1 = 00000000<br>;D2 = 00000000<br>;D2: Schleifenzähler |
|--------------------------|----------------------|----------------------------------------------------------------------------|
| MOVE.W                   | (A0) + D1            | ;Laden des zu addierenden<br>;Wortes in D1                                 |
| ADD.L                    | D1, D0               | ;Addition des Wortes in D1 zu<br>;der bereits aufgelaufenen                |
| DBRA                     | D2,START             | ;Summe in D0<br>;Wenn D2 = -1, dann Ende,<br>;sonst erneuter Schleifen-    |

,durchlauf

END

# 2. Lösung:

Der Wert von A1 wird berechnet, der die Adresse des ersten nicht mehr zu addierenden Wortes der Reihe enthält.



|          | MOVE.L                  | A0, A1                | ;Kopieren der Startadresse                                                               |
|----------|-------------------------|-----------------------|------------------------------------------------------------------------------------------|
| SCHLEIFE | ADD.L<br>CLR.L<br>CLR.L | #\$14, A1<br>D0<br>D1 | ;nach A1<br>;A1 = A0 + 20 (Bytes)<br>;D0 = 00000000<br>;D1 = 00000000                    |
|          |                         | (A0) + D1             | ;Laden des zu addierenden<br>;Wortes in D1                                               |
|          | ADD.L                   | D1, D0                | ;Addieren des Wortes zu der                                                              |
|          | CMPA.L                  | A1, A0                | ;bereits aufgelaufenen Summe<br>;Vergleich zwischen aktueller<br>;Adresse und Endadresse |
|          | BNE                     | SCHLEIFE              | ; der Tabelle<br>; Verzweigung nach SCHLEIFE,<br>, wenn $Z = 0$ , also $A0 + A1$ ;       |
|          | END                     |                       | ;sonst Ende                                                                              |

### Zahlen mit Vorzeichen:

CLR.L

CLR.L

Zur Abwechslung wird diesmal der Befehl DBcc nicht verwendet.

D0

D0

# 1. Lösung:

;D0 = 000000000

: D0 = 000000000

# 2. Lösung:

|          | MOVE.B  | #\$0A,D2  | $;D2 = x \times x \times x \times 0 A$  |
|----------|---------|-----------|-----------------------------------------|
| SCHLEIFE |         |           | 122 ANALAGIA                            |
|          | MOVE.W  | (A0) + D1 | ;Speicherinhalt in D1                   |
|          | EXT.L   | D1        | ;Vorzeichenerweiterung                  |
|          | ADD.L   | D1, D0    | ;(D1) + (D0) in D0                      |
|          | SUB.B ` | #1, D2    | (D2) = (D2) - 1                         |
|          | BNE     | SCHLEIFE  | ; Wenn D2 $-xxxxxxx00$ , $Z = 1$        |
|          | END     |           | , , , , , , , , , , , , , , , , , , , , |

# **PROGRAMM 5**

Es wird der größte Wert in einer Tabelle aus 10 Worten ohne Vorzeichen gesucht.

A0 enthalt die Anfangsadresse der Tabelle, und D0 nimmt das Ergebnis auf.

Das Flußdiagramm des Programms sehen Sie in Abb. 63.



Abb 6.3: Flußdiagramm (Programm 5)

Das Programm lautet folgendermaßen:

MOVEO #9.D2 ;D2: Schleifenzähler MOVEQ #2, D1 :D1: Indexregister MOVE.W (A0), D0 :Ersten Wert in D0 laden

**SCHLEIFE** 

CMP.W 0(A0, D1), D0 ; Vergleich zwischen dem

;aktuellen Wert und dem bis-

;herigen Maximum

BPL. POITIV MOVE. W 0 (A0, D1), D0 ; Neues Maximum in D0

N = 1 wenn D0 < (A0, D1)

:schreiben

POSITIV

DBRA D2, SCHLEIFE : Ende wenn D2 = -1**END** 

#### PROGRAMM 6

Wir wandeln eine Dezimalzahl mit Vorzeichen, die binar in 32 Bits verschlüsselt ist, in ASCII-Code um.

Die zu konvertierende Zahl steht in Register D0.

Das Ergebnis soll im Speicher ab Adresse A0 stehen, und zwar in folgender Form:



Die umzuwandelnde Zahl soll aus maximal 10 Dezimalziffern bestehen. Folglich werden für das Ergebnis 11 Bytes benötigt, 10 für die Zahl und 1 für das Vorzeichen.

Wir gehen von der folgenden Tabelle aus:

| TABWERT | 1000000000 | Wert 1 |
|---------|------------|--------|
|         | 100000000  | Wert 2 |
|         | 10000000   | Wert 3 |
|         | 1000000    |        |
|         | 100000     |        |
|         | 10000      |        |
|         | 1000       |        |
|         | 100        |        |
|         | 10         |        |
|         | 1          |        |

Es wird nun der erste Wert dieser Tabelle von der umzuwandelnden Zahl subtrahiert und nachher überprüft, ob diese Zahl kleiner war als der Tabellenwert. Die Anzahl der Subtraktionen, die durchgeführt werden müssen, bis ein negatives Ergebnis auftritt, ist dann die in ASCII zu verschlüsselnde Zahl.

Um die nächste Zahl zu berechnen, werden die Subtraktionen mit dem Wert, der sich ergeben hatte, bevor das negative Ergebnis auftrat, und dem nächsten Tabellenwert wiederholt.

# Beispiel:

2xxxxxxxxx Dezimalziffern -10000000000 1xxxxxxxxx

Das Ergebnis ist positiv, also weiter:

1xxxxxxxx -10000<u>00000</u> 0xxxxxxxx

Das Ergebnis ist immer noch positiv:

0xxxxxxxxx -10000000000

negatives Ergebnis, also Stop.

Es waren also zwei Subtraktionen nötig, bis ein negatives Ergebnis auftrat. Die Zahl, die codiert werden soll, ist demnach 2.

Bemerkung: Das Ergebnis 0xxxxxxxxx muß gesichert werden, damit die Berechnung weitergehen kann. In unserem Beispiel muß dazu der Wert 1000000000 zu dem negativen Ergebnis addiert werden.

## ASCII-Tabelle der Dezimalziffern

| dezimal | ASCII (hex) |
|---------|-------------|
| 0       | 30          |
| 1       | 31          |
| 2       | 32          |
| 3       | 33          |
| 4       | 34          |
| 5       | 35          |
| 6       | 36          |
| 7       | 37          |
| 8       | 38          |
| 9       | 39          |

Mit dem Programm finden wir sofort den ASCII-Code der Ziffer, und zwar abhängig von der Anzahl der Subtraktionen. Bei jeder Subtraktion wird — solange das Ergebnis größer als 0 ist — die Zahl \$D0 dekrementiert, die das Zweierkomplement der Zahl \$30 ist.

Auf diese Weise wird bei der Zahl 1 eine einzige Subtraktion durchgeführt, nämlich:

$$D0-1=CF$$

Im Zweierkomplement ergibt das \$31, den ASCII-Code von 1.

Für die Zahl 2 sind zwei Subtraktionen notwendig, nämlich noch:

Im Zweierkomplement ist das \$32, der ASCII-Code von 2.

Das Flußdiagramm dieses Programms zeigen wir in Abb. 6.4.



Abb 6 4: Flußdiagramm (Programm 6)

# Das Programm dazu sieht so aus:

|             | TST.L<br>BGE    | # 9, D1<br># \$2B, (A0)<br>D0<br>POSITIV<br>#\$2D, (A0) | ;Initialisierung des Stellenzählers<br>;ASCII-Code des Vorzeichens +<br>;in die Ergebnistabelle eintragen<br>;Test, ob die zu konvertierende<br>;Zahl positiv oder negativ ist<br>;Wenn positiv, Fortsetzung des<br>;Programms<br>;ASCII-Code des Vorzeichens - |
|-------------|-----------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| POSITIV     | NEG.L           | D0                                                      | ;in die Ergebnistabelle eintragen<br>;Zweierkomplement der Zahl<br>;bilden                                                                                                                                                                                      |
| 1031114     | ADDQ            | # 1, A0                                                 | ;Vorbereiten von A0 für das<br>;Laden des nächsten Ergebnis-<br>;bytes in Speicher                                                                                                                                                                              |
| NAME TO THE | LEA             | TABWERT, A1                                             | ;A1 = Adresse von TABWERT                                                                                                                                                                                                                                       |
| WERT        | MOVE.E<br>MOVEQ | (A1) +, D3<br># \$D0, D2                                | ;Laden des Stellenwertes in D3<br>;D2 = \$30                                                                                                                                                                                                                    |
| SUBTR       | SUB.L<br>DBM1   | D3, D0<br>D2, SUBTR                                     | "Subtraktion des Stellenwertes<br>;Wenn Ergebnis > 0, muß eine<br>;weitere Subtraktion durchge-<br>;führt werden, und D2 muß<br>;dekrementiert werden<br>;Wenn Ergebnis < 0, erfolgt<br>;keine weitere Subtraktion, und<br>;D2 bleibt unverändert               |
|             | NEG.B           | D2                                                      | ;Übergang zur positiven ASCII-                                                                                                                                                                                                                                  |
|             | MOVE.B<br>ADD L | D2, (A0) +<br>D3, D0                                    | ;Darstellung<br>;Eintragen in die Ergebnistabelle<br>;Es wurde eine Subtraktion<br>;zuviel ausgeführt                                                                                                                                                           |
|             | DBRA            | D1, WERT                                                | ;Schon 10 Žiffern durch:<br>;Ja, dann Ende<br>;Nein: Der Zyklus der Subtrak-                                                                                                                                                                                    |
|             | END             |                                                         | ;tion beginnt von vorn                                                                                                                                                                                                                                          |
|             |                 |                                                         |                                                                                                                                                                                                                                                                 |

# **PROGRAMM 7**

Wir wollen eine 64-Bit-Addition mit den Zahlen N1 und N2 durchführen, die, wie in Abb. 6.5 gezeigt, im Speicher liegen.



Abb. 6.5. Speicherorganisation (Programm 7)

Um diese 64-Bit-Addition zu realisieren, führen wir zwei 32-Bit-Additionen mit Hilfe des ADDX-Befehls aus, der uns auch das Setzen der Bedingungscodes X und Z ermöglicht:

- Das Erweiterungsbit X muß mit 0 initialisiert werden.
- Der Bedingungscode Z muß mit 1 initialisiert werden, denn der ADDX-Befehl bewirkt ein Zurücksetzen von Z auf 0, wenn das Ergebnis nicht 0 ist, sonst bleibt Z unverändert.

# Beispiel:

Z=1 zu Beginn (vor ADDX)

#### 1. Fall:

Wenn das erste Ergebnis 0 ist, bleibt Z unverändert, also 1.

- Wenn das zweite Ergebnis nicht 0 ist, wird Z auf 0 gesetzt.
- Das Endergebnis ist also ungleich 0 und Z=0, was korrekt ist.

#### 2. Fall:

- Wenn das erste Ergebnis nicht 0 ist, wird Z auf 0 gesetzt.
- Wenn das zweite Ergebnis 0 ist, bleibt Z unverändert, also 0.
   Das Endergebnis ist also ungleich 0 und Z=0, was korrekt ist.

#### 3. Fall:

- Wenn das erste Ergebnis 0 ist, bleibt Z unverändert, also 1.
- Wenn das zweite Ergebnis 0 ist, bleibt Z unverändert, also 1.
- Das Endergebnis ist also 0 und Z=1, was korrekt ist.

Dasselbe Prinzip gilt für die Befehle ABCD, NBCD, NEGX, SBCD und SUBX.

Bemerkung: Um das Ergebnis in den Speicher zu bringen, darf keinesfalls der MOVE-Befehl verwendet werden, da er die Bedingungscodes verändert. Dann würde nämlich im 2. Fall, bei dem das Ergebnis 0 war, durch den MOVE-Befehl der Bedingungscode Z auf 1 gesetzt, was falsch wäre.

Um dieses Problem zu lösen, setzt man den Befehl MOVEM ein. Das Programm läßt sich nunmehr ohne Schwierigkeiten verwirklichen:

|          | MOVEQ              | #1,D2          | ;Initialisierung des Schleifen-<br>;zählers                                      |
|----------|--------------------|----------------|----------------------------------------------------------------------------------|
|          | LEA                | (ADRN1+8), A   | 0;Setzen des Zeigers in A0<br>;unter Berücksichtigung der<br>;Predekrementierung |
|          | LEA<br>LEA<br>MOVE | (ADRES + 8), A | 1; gleichfalls für A1<br>2; gleichfalls für A2<br>; X = 0, Z = 1                 |
| SCHLEIFE | =                  | •              |                                                                                  |
|          | MOVE.L             | -(A0), D0      | ;Ersten Operanden in D0<br>;laden                                                |
|          | MOVE.L             | -(A1), D1      | ;Zweiten Operanden in D1<br>;laden                                               |
|          | ADDX.L             | D0, D1         | Addition                                                                         |
|          | MOVEM.L            | D1, -(A2)      | ;Ergebnis in den Speicher<br>;schreiben                                          |
|          | DBRA               | D2, SCHLEIFE   | ;Wenn D2 = -1, dann Ende,<br>;sonst erneuter Schleifen-                          |
|          |                    |                | :durchlauf                                                                       |
|          | END                |                | ,our ontaut                                                                      |

# **PROGRAMM 8**

Wir möchten mit Hilfe eines Unterprogramms Worte einer Tabelle in absteigender Reihenfolge sortieren.

Das Register A0 zeigt auf die Adresse des Tabellenanfangs und wird mit ANFTAB initialisiert.

Die Tabelle endet bei der Adresse ENDTAB.

Vorgehensweise: Nacheinander mussen jeweils zwei Elemente N0 und N1 miteinander verglichen werden:

- Ist N0>N1, dann wird zum n\u00e4chsten Vergleich mit N1 und N2 \u00fcbergegangen.
- Ist N0<N1, dann werden die Plätze von N0 und N1 in der Tabelle vertauscht, und die Tabelle wird von vorn durchgearbeitet.</li>

| ANFTAB   | NO  |
|----------|-----|
|          | N 1 |
|          | N 2 |
|          | N3  |
|          |     |
|          |     |
| Beispiel |     |
|          | 0.0 |
|          | 0.4 |
|          | 0.0 |
|          | 02  |
|          | 01  |
|          | 03  |

0004 > 0002 - kein Tausch0002 < 0103 - Werte werden vertauscht

| 0.0 |
|-----|
| 0.4 |
| 0 1 |
| 03  |
| 0.0 |
| 0.5 |
|     |

Die Untersuchung beginnt wieder am Anfang der Tabelle:

0004 < 0103 - Werte werden vertauscht

| 0.1 |
|-----|
| 03  |
| 00  |
| 0 4 |
| 00  |
| 02  |
|     |

Das Flußdiagramm dieser Problemlösung ist in Abb 6.6 zu sehen.

Das Programm sieht so aus:

| CT A DT        | LEA<br>LEA<br>MOVE.L  |                          | ;Initialisierung<br>;Initialisierung<br>;Retten der Anfangsadresse                                                    |
|----------------|-----------------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------|
| START<br>FOLGE | MOVE.L                | A2, A0                   | ;Wiederherstellen der Anfangs-<br>;adresse                                                                            |
| FOLUE          | CMPM.W                | (A0) + , (A0)            | ;Vergleich zweier aufeinander-<br>;folgender Worte                                                                    |
|                | BHI                   | TAUSCH                   | ;Abhängig vom Ergebnis des<br>;Vergleichs werden die Worte<br>;getauscht oder nicht                                   |
| r aticcii      | TST.W<br>CMP.L<br>BNE | -(A0)<br>A0, A1<br>FOLGE | ;Dekrementieren von A0<br>;Test auf Tabellenende<br>;Wenn Z=0, gehe zu FOLGE<br>;Rückkehr aus dem Unter-<br>;programm |
| TAUSCH         | MOVE.W                | -(A0), D0                | ;Austausch von 2 Worten in der<br>;Tabelle                                                                            |



Abb. 6.6. Flußdiagramm (Programm 8)

#### PROGRAMM 9

Wir wollen eine 32-Bit-Multiplikation zweier Zahlen ohne Vorzeichen durchführen.

Die Operanden N1 und N2 sowie die Zeiger sind im Schema der Abb. 6.7 zu sehen.



Abb. 6.7: Speicherorganisation (Programm 9)

Das Rechenschema mit N1-33334444 und N2=11112222 ist in Abb. 6.8 veranschaulicht.

N1 = 33334444 et N2 = 11112222.



Abb. 6.8: Rechenschema (Programm 9)

In diesem Beispiel wird das Ergebnis im Speicher gebildet, so wie die Abb. 6.9 es zeigt.



Abb. 6.9: Speicheraufhau nach dem Rechenbeispiel (Programm 9)

# Das Programm sieht so aus:

| LAENGE   | EQU                     | 1                                  | ;Länge der Operanden in<br>;Bytes                                                                                                                                       |
|----------|-------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | LEA                     | ADN1+4, A0                         | ;A $0 =$ Adresse des nieder-                                                                                                                                            |
|          | LEA<br>LEA              | ADN2+4, A1<br>ADRES, A2            | ;wertigen Anteils von N1 + 1<br>;gleichfalls für N2<br>;A2 = Adresse des höher-<br>;wertigen Anteils des zu-                                                            |
|          | MOVE.L                  | (2 * LAENGE) / 2                   | ;künftigen Ergebnisses - 1, D0 ;Ergebnis nullsetzen                                                                                                                     |
| LOESCH   |                         |                                    | ,21500110110100001                                                                                                                                                      |
|          | CLR.W<br>DBRA<br>MOVE.L | (A2)+<br>D0, LOESCH<br>+ LAENGE/2- | ;<br>;<br>1. D1                                                                                                                                                         |
|          |                         |                                    | ;D1 = 1, um den niederwer-<br>;tigen Anteil von N2 mit<br>;dem niederwertigen Anteil<br>;von N1 zu multiplizieren,<br>;danach mit dem höherwer-<br>;tigen Anteil von N1 |
| MULT     |                         |                                    | , agent men von vo                                                                                                                                                      |
|          | CLR.L                   | D0                                 |                                                                                                                                                                         |
|          | MOVE.L                  | # LAENGE / 2 -                     |                                                                                                                                                                         |
|          |                         |                                    | ;D2=1, um den höherwerti-<br>;gen Anteil von N2 mit dem<br>;niederwertigen Anteil von<br>;N1 zu multiplizieren, da-<br>;nach mit dem höherwerti-<br>;gen Anteil von N1. |
|          | MOVE.W                  | ′ −(A1), D4                        | ;Laden der Operanden                                                                                                                                                    |
| SCHLEIFE |                         | <b>7</b>                           | *                                                                                                                                                                       |
|          | MOVE.W                  | ' -(A0), D3                        | •                                                                                                                                                                       |
|          | MULU                    | D4, D3                             | ;Multiplikation                                                                                                                                                         |
|          | ADD.L                   | D3, D0                             | ;Addition der vorhergehen-                                                                                                                                              |
|          | ar b.                   | ***                                | ;den niederwertigen Änteile                                                                                                                                             |
|          | CLR.L<br>MOVE.W         | D3<br>7 -(A2), D3                  | ;Addition des vorhergehen-<br>;den Ergebnisses und Er-<br>;stellen des endgültigen Er-                                                                                  |
|          |                         |                                    | ;gebnisses.                                                                                                                                                             |
|          | ADD.L                   |                                    | ;gebnisses.                                                                                                                                                             |
|          | ADD.L<br>MOVE.W         |                                    | ;gebnisses.                                                                                                                                                             |

| CLR.W | D0              | Übertragung des höherwer-<br>tigen Anteils in den nieder-                                                                       |
|-------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| SWAP  | D0              | wertigen                                                                                                                        |
| DBRA  |                 | ;                                                                                                                               |
|       | D2, SCHLEIFE    |                                                                                                                                 |
| MOVE  | D0, -(A2)       | ;Erstellung des Ergebnisses                                                                                                     |
| LEA   | LAENGE (A0), A0 | ;Reinitialisierung, um einen                                                                                                    |
|       | ```             | ;anderen Operandenteil zu<br>;finden und die vorherge-<br>;henden Ergebnisse für die<br>;zukünftigen Additionen<br>;anzurechnen |
| LEA   | LAENGE (A2), A2 | •                                                                                                                               |
|       |                 | 3                                                                                                                               |
| DBRA  | D1, MULT        |                                                                                                                                 |
| END   |                 |                                                                                                                                 |

# Die anderen Prozessoren der 68000-Familie

#### **DER MC68008**

Hier handelt es sich um einen Prozessor aus der 68000-Familie, der zwar intern eine 32-Bit-Architektur hat, aber einen auf 8 Bits reduzierten Datenbus D0 D7 besitzt.

Dieser Mikroprozessor mit seinen 48 Anschlußstiften stellt eine weniger komplexe und kostengünstigere Alternative dar, die trotzdem die Vorteile eines 32-Bit-Systems bietet.

Die interne Struktur des MC68008 ist mit der des MC68000 identisch, d. h. er besitzt 17 32-Bit-Register:

8 Datenregister: D0, ..., D7 7 Adreßregister: A0, ..., A6 1 Stapelzeigerregister: A7 1 Programmzähler: PC

Das 16-Bit-Statusregister SR hat den gleichen Aufbau wie das des 68000.

Auch der Stapelzeiger A7 hängt wie beim 68000 unmittelbar vom Zustand des Prozessors ab (Benutzer- oder Überwachermodus).

Dennoch gibt es gewisse Unterschiede zwischen dem 68008 und dem 68000. Abb. 7.1 zeigt die Anschlüsse des 68008.

Die Unterschiede, die zu beachten sind, sind die folgenden:

Es gibt nur eine einzige Stromversorgung VCC.
 Bei der Buskontrolle im Synchron-Modus wird nicht das Signal VMA erzeugt.



Abb 71: Die Anschlüsse des MC68008

- Der Adreßbus;umfaßt die Adreßleitungen A0 bis A19
- Der Datenbus ist ein 8-Bit-Bus: D0 bis D7.
- Bei der Bussteuerung im asynchronen Modus erfolgt die Bestätigung der Daten über einen DS-Anschlußstift anstelle von UDS und LDS.
- Die Buszuweisungssteuerung erfolgt über zwei Anschlußstifte, die den Eingang BGACK ersetzen.
- Die Steuerung für Unterbrechungen bedient sich zweier Eingänge anstatt drei. Die Leitungen 1 P L 0 und 1 P L 2 sind verbunden, nur I P L 1 ist separat.
- Der Befehlsvorrat ist fast der gleiche wie beim 68000. Lediglich sechs Befehle sind nicht vorhanden.

#### LESEZYKLUS

Der Lesezyklus für ein Byte ist identisch mit dem des 68000, hier aber mit dem Adreßbus A0-A19 anstatt A1-A23 und mit  $\overline{DS}$  anstatt  $\overline{UDS}$  und  $\overline{LDS}$ .

Das Lesen eines Wortes ist jedoch in zwei Zyklen aufgeteilt:

Lesezyklus des ersten Bytes Lesezyklus des zweiten Bytes

Das Ablauf- und das Zeitdiagramm dieses Zyklus sehen Sie in Abb. 7.2 bzw. 7.3.



Abb 7. 2. Ablaufplan des Lesezyklus eines Wortes

#### DER BEFEHLSSATZ

Die Adressierungsarten sind die gleichen wie beim 68000. Lediglich der Befehlssatz unterscheidet sich geringfügig, da sechs Befehle fehlen. Und zwar handelt es sich um die Befehle:

ANDI mit SR ANDI mit CCR EORI mit SR EORI mit CCR ORI mit SR ORI mit CCR

#### **DER MC68010**

#### ALLGEMEINES

Das Ziel des nun folgenden Kapitels ist es, die Verbesserungen dieses Prozessors gegenüber dem MC68000 aufzuzeigen.

Der MC68010, ein 16-Bit-Mikroprozessor, stellt eine Erweiterung des MC68000 dar. Er bietet die Möglichkeiten der virtuellen Maschine und des virtuellen Speichers, bleibt aber gleichzeitig kompatibel zum 68000. Eine sinnvolle Forderung für Mitglieder einer Familie ist nämlich, daß die für die anderen Mitglieder dieser Familie geschriebene Software ohne Änderung lauffähig ist.

Die wichtigsten Merkmale des 68010 sind die folgenden:

- direktes 16-Megabyte-Adressierungsspektrum
- 17 32-Bit-Daten- und Adreßregister
- Unterstützung von virtuellem Speicher und virtueller Maschine
- 57 Befehlstypen
- 14 Adressierungsarten

# Konzept des virtuellen Speichers

Ursprünglich ist das Konzept des virtuellen Speichers aus der Notwendig keit entstanden, kostspielige Speicherkapazität optimal zu nutzen. Ein System mit virtuellem Speicher ermöglicht nämlich dem Benutzer, Programme mit logischen (virtuellen) Adressen auszuführen, ohne sich um deren physikalische Existenz kümmern zu müssen.

Ein Speicherorganisationssystem, das die Hardware und die Software einschließt, paßt die Adressen des Programmierers dem geringen physischen Speicher an. Der Anwender benötigt keine Kenntnis über den Speicherplatz, an dem sein Programm abgelegt wurde.

Die physischen und virtuellen Adreßraume werden in Seiten aufgeteilt. Wird ein Zugriff zu einer Adresse auf einer Seite durchgeführt, die im physischen Speicher nicht vorhanden ist, so wird eine Ausnahmeverarbeitung eingeleitet. Das virtuelle Speichersystem kann diesen Fehler beheben, indem es die Seite ausfindig macht und sie durch eine der Seiten des physischen Speichers ersetzt.

Während dieses Ersetzungsvorgangs ist der Prozessor frei, um andere Anwender zu bedienen, und bietet so außerdem noch die Möglichkeit des Multiprogramms. Nach der Behebung des Fehlers kann der Prozessor sodann die Ausführung des unterbrochenen Programms wieder aufnehmen.

Ein Prozessor, der eine virtuelle Speicherorganisation ermöglicht, muß also in der Lage sein, die folgenden drei Basisfunktionen auszuführen: Fehlererkennung, Retten der gesamten Information, die notwendig ist, um den Fehler zu beseitigen, und Durchführen einer Ausnahmeprozedur und danach Wiederherstellung des alten Zustands und Wiederaufnahme der Verarbeitung

# Begriff der virtuellen Maschine

Bei diesem System können die Anwenderprogramme auf Elemente wie Plattenspeicher-Kontroller, Bildschirm-Kontroller, Drucker etc. zugreifen, obwohl es sie im System gar nicht gibt.

Eine typische Anwendung dafür ist die Fehlerbeseitigung in eine Software, die noch nicht funktionsfähig ist.

#### INTERNE STRUKTUR DES MC68010

Die interne Struktur des MC68010 ist in Abb. 7.13 dargestellt.



Abb. 7.13: Die Register des MC68010

# Das Vektorbasisregister VBR

Dieses 32-Bit-Register kann dank des privilegierten Befehls MOVEC geladen und gelesen werden. Es wird bei der Errechnung der Vektoradresse eingesetzt.

# Die alternierenden Funktionscode-Register SFC und DFC

Diese 3-Bit-Register können durch den MOVEC-Befehl geladen und gelesen werden. Der Befchl MOVES benutzt nur diese Register. Sie

erlauben dem Supervisor-System den Zugriff zu anderen adressierbaren Bereichen als den Supervisor-Daten.

# DIE ANSCHLÜSSE DES MC68010



Abb. 7.14: Die Anschlüsse des MC68010

Der MC 68010 hat genau die gleichen Anschlüsse wie der MC68000. Es treten nur ein paar Varianten bei den Zuständen bestimmter Signale (FC0-FC2) und Prozeduren (BERR) auf.

Eine Tabelle der Funktionscodes ist in Abb. 7.15 zu sehen.

| FC2 | FC1 | FC0 | Zyklustyp           |
|-----|-----|-----|---------------------|
| L   | L   | L   | reserviert          |
| L   | L   | н   | Anwender-Daten      |
| L   | Н   | L   | Anwender-Programm   |
| L   | Н   | н   | reserviert          |
| Н   | L   | L   | reserviert          |
| Н   | L   | н   | Supervisor-Daten    |
| Н   | H   | L   | Supervisor-Programm |
| Н   | Н   | н   | CPU-Bereich         |

Abb 715: Tabelle der Funktionscodes

Die Ports werden auf die oberen Bits des Datenbusses geladen, z. B.:

- ein 16-Bit-Port D16-D31;
- ein 8-Bit-Port D24-D31

Diese Transfers werden von den Signalen DSack0 (Data Transfer and Size acknowledge) und DSack1 gesteuert.

Diese zwei Eingangssignale funktionieren ähnlich wie DTACK; sie geben an, ob es sich um 8-, 16- oder 32-Bit-Übertragungen handelt.

Parallel dazu geben die beiden Signale Siz0 und Siz1 die noch zu übertragende Bytezahl an

Somit zeigen während des Lesevorgangs eines Doppelwortes, beim ersten Zyklus diese Signale noch 4 Bytes an. Wenn wir es mit einem 8-Bit-Port zu tun haben, sind nach dem zweiten Zyklus noch 3 Bytes zu übertragen.

# Ungerade Adressen auf dem Bus

Der MC68020 läßt Wort- und Doppelwortadressierung (auf der Operandenebene) mit ungeraden Adressen zu. Ein Adreßfehler wird nur im Fall eines an einer ungeraden Adresse plazierten Befehls erzeugt.

## DIE PROGRAMMIERUNG DES MC68020

Die Programmierung wird durch die Flexibilität der Befehle vereinfacht. Wir haben z. B. folgende Verbesserungen:

- zusätzliche Befehle, die auf höhere Programmiersprachen ausgerichtet sind;
- Befehle, die beim MC68010 nur mit 8 oder 16 Bits arbeiten, sind hier mit 32 Bits möglich;
- elegante Adressierung bei Verzweigungen:
   32-Bit Adreßdistanzwerte sind erlaubt;
- besondere Adressierungsarten, die z. B. Verschiebung in ein Indexregister oder zusätzliche Parameter wie z. B. den Rangordnungsfaktor erlauben;
- ungefähr 16 zusätzliche Befehle wie TRAPcc, der eine Erweiterung von TRAPV ist.

# Anhang A

# Ausführungszeiten der Befehle des MC 68000

# Berechnung der effektiven Adresse

| -                                      | Adressierungart                                                                              | Byte, Wort        | Doppelwort         |
|----------------------------------------|----------------------------------------------------------------------------------------------|-------------------|--------------------|
|                                        | Register                                                                                     |                   |                    |
| Dn<br>An                               | Datenregister direkt<br>AdreBregister direkt                                                 | 0(0/0)            | 0(0/0)             |
| (An)<br>(An) +                         | Speicher Adreßregister indirekt Adreßregister indirekt mit Postinkrementierung               | 4(1/0)<br>4(1/0)  | 8(2 0)<br>8(2/0)   |
| — (An)<br>d(An)                        | Adreßregister indirekt mit Predekrementierung<br>Adreßregister ind rekt mit Adreßdistanzwert | 6(1/0)<br>8(2/0)  | 10(2/0)<br>12(3/0) |
| d(An, lx)*                             | Adreßregister indirekt mit Index absolut kurz                                                | 10(2/0)<br>8(2/0) | 14(3′0)<br>12(3/0) |
| πα L<br>d(PC)                          | absolut lang<br>Programmzähler mit Adreßdistanzwert                                          | 12(3/0)<br>8(2/0) | 16(4-0)<br>12(3/0) |
| d(PC, <sub>b</sub> )* # <sub>xxx</sub> | Programmzähler mit Index unmittelber                                                         | 10(2/0)<br>4(1/0) | 14(3/0)<br>8(2/0)  |

<sup>\*</sup> Die Länge des Indexregisters (ix) beeinflußt nicht die Ausführungszeit

#### MOVE (Byte und Wort)

|                                 |                              |                              |                               |                               | Ziel                          |                               |                               |                               |                            |
|---------------------------------|------------------------------|------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|----------------------------|
| Quelle                          | Dn                           | An                           | (An)                          | (An) +                        | (Ап)                          | d(An)                         | d(An, ix)*                    | xxx W                         | XXX L                      |
| Dn                              | 4(1/0)                       | 4(1/0)                       | 8(1/1)                        | 8(1/1)                        | 8(1/1)                        | 12(2/1)                       | 14(2/1)                       | 12(2/1)                       | 16(3/1)                    |
| An                              | 4(1/0)                       | 4(1/0)                       | 8(1/1)                        | 8(1/1)                        | 8(1/1)                        | 12(2/1)                       | 14(2/1)                       | 12(2/1)                       | 16(3/1)                    |
| (An)                            | 8(2/0)                       | 8(2/0)                       | 12(2/1)                       | 12(2/1)                       | 12(2/1)                       | 16(3/1)                       | 18(3/1)                       | 16(3/1)                       | 20(4/1)                    |
| (An) +                          | 8(2/0)                       | 8(2/0)                       | 12(2/1)                       | 12(2/1)                       | 12(2/1)                       | 16(3/1)                       | 18(3/1)                       | 16(3/1)                       | 20(4/1)                    |
| - (An)                          | 10(2/0)                      | 10(2/0)                      | 14(2/1)                       | 14(2/1)                       | 14(2/1)                       | 18(3/1)                       | 20(3/1)                       | 18(3/1)                       | 22(4/1)                    |
| d(An)                           | 12(3/0)                      | 12(3/0)                      | 16(3/1)                       | 16(3/1)                       | 16(3/1)                       | 20(4/1)                       | 22(4/1)                       | 20(4/1)                       | 24(5/1)                    |
| d(An, Ir)* xxx W                | 14(3/0)                      | 14(3/0)                      | 18(3/1)                       | 18(3/1)                       | 18(3/1)                       | 22(4/1)                       | 24(4/1)                       | 22(4/1)                       | 26(5/1                     |
|                                 | 12(3/0)                      | 12(3/0)                      | 16(3/1)                       | 16(3/1)                       | 16(3/1)                       | 20(4/1)                       | 22(4/1)                       | 20(4/1)                       | 24(5/1                     |
|                                 | 16(4/0)                      | 16(4/0)                      | 20(4/1)                       | 20(4/1)                       | 20(4/1)                       | 24(5/1)                       | 26(5/1)                       | 24(5/1)                       | 28(6/1                     |
| d(PC)<br>d(PC, <sub>(x</sub> )* | 12(3/0)<br>14(3/0)<br>8(2/0) | 12(3/0)<br>14(3/0)<br>8(2/0) | 16(3/1)<br>18(3/1)<br>12(2/1) | 16(3/1)<br>18(3/1)<br>12(2/1) | 16(3/1)<br>18(3/1)<br>12(2/1) | 20(4/1)<br>22(4/1)<br>16(3/1) | 22(4·1)<br>24(4·1)<br>18(3/1) | 20(4/1)<br>22(4/1)<br>16(3/1) | 24(5/1<br>26(5/1<br>20(4/1 |

<sup>\*</sup> Die Länge des Indexregisters beeinflußt nicht die Ausführungszeit

# MOVE (Doppelwort)

| Quele                  |         |         | Ziel    |         |         |         |            |         |         |
|------------------------|---------|---------|---------|---------|---------|---------|------------|---------|---------|
| Guerie                 | Dn      | An      | (An)    | (An) +  | - (An)  | d(An)   | d(An, ix)* | W xxx   | xxx L   |
| Dn                     | 4(1/0)  | 4(1/0)  | 12(1/2) | 12(1/2) | 14(1/2) | 16(2/2) | 18(2/2)    | 16(2/2) | 20(3/2) |
| An                     | 4(1/0)  | 4(1/0)  | 12(1/2) | 12(1/2) | 14(1/2) | 16(2/2) | 18(2/2)    | 16(2 2) | 20(3/2) |
| (An)                   | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2)    | 24(4/2) | 28(5/2) |
| (An) +                 | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2)    | 24(4 2) | 28(5/2) |
| - (An)                 | 14(3/0) | 14(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2)    | 26(4/2) | 30(5/2) |
| d(An)                  | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2)    | 28(5/2) | 32(6/2) |
| d(An, lx)*             | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2)    | 30(5/2) | 34(6/2) |
| xxx W                  | 16(4/0) | 16(4/0) | 24(4 2) | 24(4/2) | 24(4/2) | 28,5/2) | 30(5/2)    | 28(5/2) | 32(6/2) |
| xxx L                  | 20(5/0) | 20(5/0) | 28(5/2) | 28(5/2) | 28(5/2) | 32(6/2) | 34(6/2)    | 32(6/2) | 36(7/2) |
| d(PC)                  | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2)    | 28(5/2) | 32(5/2) |
| d(PC, <sub>ls</sub> )* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2)    | 30(5/2) | 34(6/2) |
| #xxx                   | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2)    | 24(4/2) | 28(5 2) |

<sup>\*</sup> Die Größe des Indexregisters beeinflußt nicht die Ausführungszeit

#### Gebräuchliche Befehle

| Befehl | Größe      | op <ea>, Ant</ea> | op < ea>, Dn       | op Dn, < M> |
|--------|------------|-------------------|--------------------|-------------|
| ADD    | Byle Worl  | B(1/0) +          | 4(1/0) +           | B(1/1) +    |
|        | Boppelwort | 6(1/0) +**        | 6(1/0) + **        | 12(1/2) +   |
| AND    | Byte Wort  | -                 | 4(1/0) +           | 8(1/1) +    |
|        | Doppelwort | _                 | 6(1/0) +**         | 12(1/2) +   |
| CMP    | Byle Worl  | 6(1/0) +          | 4(1/0) +           | -           |
|        | Doppelwort | 5(1/0) +          | 6(1/0) +           | -           |
| DIVS   | -          | _                 | 158(1/0) +*        | -           |
| DIVU   | - 1        | -                 | 140(1/0) +*        | -           |
| EOR    | Byte Wort  | -                 | 4(1/0)***          | B(1/1) +    |
|        | Doppelwort | _                 | 8(1/0)***          | 12(1/2) +   |
| MULS   | -          | _                 | <b>70</b> (1/0) +* |             |
| MULU   | -          | -                 | 70(1/0) +*         |             |
| OR     | Byle, Worl | -                 | 4(1/0) +           | 8(1/1) +    |
|        | Doppelwort |                   | 6(1/0) + **        | 12(1/2) +   |
| SUB    | Byle, Worl | 8(1/0) +          | 4(1/0) +           | 8(1/1) +    |
|        | Doppelwort | 6(1/0) +**        | 6(1/0) +**         | 12(1 2) +   |

#### Beachten Sie:

- + Addieren Sie die Berechnungszeit für die effektive Adresse
- t Nur Wort und Doppelwort
- \* Zeigt Maximalwert an
- \*\* Die Basiszeit von 6 Taktzyklen erh\u00f6ht sich auf 8, wenn die Adressierungsart Register direkt oder unmittelbar ist (Zeit zur Berechnung der effektiven Adresse muß zus\u00e4tzl ch add ert werden...)
- \*\*\* Die einzige verfügbare effektive Adressierungsart ist Datenregister direkt.

DIVS, DIVU – Der Dividier-Algorithmus, den der MC68000 verwendet, bewirkt daß sich die Zeiten für den günstigsten und den ungünstigsten Fall nur um 10% unterscheiden

MULS, MULU Der Multipflizier-Algorithmus benötigt 38+2n Taktzyklen, wobei n definiert ist als MULU n= Anzahl der Einsen in der <EA>

MULS n = Zusammenfügen der <EA> und einer 0 als LSB in ist die Anzahl der 10- oder 01-Muster in der 17-Bit-Quelle. Der ungunstigste Fall tritt dann auf, wenn die Quelle \$5555 ist.

#### Unmittelbare Befehle

| Belehl | Größe      | op ≢, Dn | op ≢, An | op #, M   |
|--------|------------|----------|----------|-----------|
| ADDI   | Byte, Wort | 8(2/0)   | -        | 12(2/1) + |
| 71001  | Doppelwort | 16(3/0)  | -        | 20(3/2) + |
| ADDQ   | Byte, Wort | 4(1/0) + | 8(1/0)"  | B(1/1) +  |
| ,1004  | Doppe wort | 8(1/0)   | 8(1/0)   | 12(1/2) + |
| AND    | Byte, Wort | 8(2/0)   | -        | 12(2/1) + |
| ,      | Doppelworl | 16(3/0)  | -        | 20(3/1) + |
| CMPI   | Byte, Wort | 8(2/0)   | -        | 8(2/0) +  |
|        | Doppelwart | 14(3/0)  | -        | 12(3/0) + |
| EORI   | Byte, Wort | 8(2/0)   | -        | 12(2/1) + |
| 20,    | Doppelwort | 16(3/0)  | -        | 20(3/2) + |
| MOVEQ  | Doppelwort | 4(1/0)   | -        | -         |
| ORI    | Byte, Wort | 8(21/0)  | -        | 12(2/1) + |
| G / II | Doppelwort | 16(3/0)  |          | 20(3/2) + |
| SUBI   | Byte, Wort | 8(2/0)   |          | 12(2/1) + |
| 300    | Doppelwort | 16(3/0)  | -        | 20(3/2) + |
| SUBQ   | Byte, Wort | 4(1/0)   | 8(1/0)*  | 8(1/1) +  |
| 0000   | Doppelwort | 8(1/0)   | 8(1/0)   | 12(1/2) + |

<sup>+</sup> Addieren Sie die Berechnungszeit für die effektive Adresse

# Befehle, die nur einen einzigen Operanden verwenden

| Befehl | Größe        | Register | Speicher  |
|--------|--------------|----------|-----------|
| CLR    | Byte, Wort   | 4(1/0)   | 8(1/1)+   |
| OLIT   | Doppelwort   | 6(1/0)   | 12(1/2)+  |
| NBCO   | Byle         | 6(1/0    | 8(1/1)+   |
| NEG    | Byte, Wort   | 4(1/0)   | 8(1/1) +_ |
| ****   | Doppelwort   | 8(1/0)   | 12(1/2) + |
| NEGX   | Byte, Wort   | 4(1/0)   | 8(1/1) ±  |
|        | Doppelwort   | 6(1/0)   | 12(1/2) + |
| NOT    | Byte, Wort   | 4(1/0)   | 8(1/1) +  |
|        | Doppelwort   | 6(1/0)   | 12(1/2) + |
| SCC    | Byte, unwahr | 4(1/0)   | 8(1/1) +  |
| OCC    | Byte, wahr   | 6(1/0)   | 8(1/1) +  |
| TAS    | Byte         | 4(1/0)   | 10(1/1) + |
| TST    | Byte, Wort   | 4(1/0)   | 4(1/0) +  |
| 101    | Doppelwort   | 4(1/0)   | 4(1/0)    |

<sup>+</sup> Addieren Sie die Berechnungszeit für die effektive Adresse

Nur Wort

### Schiebe- und Rotierbefehle

| Befehl     | Größe      | Register    | Speicher |
|------------|------------|-------------|----------|
| ASR, ASL   | Byte, Wort | 6 + 2n(1/0) | 8(1/1) + |
|            | Doppelwort | 8 + 2n(1/0) | -        |
| LSR LSL    | Byte, Wort | 6 + 2n(1/0) | 8(1/1) + |
|            | Doppelwort | 8 + 2n(1/0) | -        |
| ROP, ROL   | Byte, Wort | 6 + 2n(1/0) | 8(1/1) + |
|            | Doppelwort | 8 + 2n(1/0) | -        |
| ROXR, ROXL | Byte, Wort | 6 + 2n(1/0) | 8(1/1) + |
|            | Doppelwort | 8 + 2n(1/0) | -44      |

<sup>+</sup> Addieren Sie die zur Berechnung der effektiven Adresse benötigte Zeit

# Bitmanipulation

| Befehl | Größe      | Dyna     | misch     | Statisch |           |  |
|--------|------------|----------|-----------|----------|-----------|--|
|        | 0.0%       | Register | Speicher  | Register | Speicher  |  |
| BCHG   | Byte       |          | 8(1/1) +- | -        | 12(2:1) + |  |
|        | Doppelwort | B(1/0)*  |           | 12(2/0)* | -         |  |
| BCLR - | Byte       | -        | 8(1/1) +  | -        | 12(2,1) + |  |
|        | Doppelworl | 10(1/0)* |           | 14(2/0)* | -         |  |
| BSET   | Byte       | _        | 8(1 1) +  | _        | 12(2/1) + |  |
|        | Doppewort  | 8(1/0)*  | -         | 12(2/0)* | _         |  |
| втят   | Byte       | -        | 4(1/1)+   | -        | 8(2/1) +  |  |
|        | Doppeiwort | 6(1/0)*  | -         | 10(2/0)* |           |  |

<sup>+</sup> Addieren Sie die zur Berechnung der effekt von Adresse benötigte Zeit

# Bedingte Befehle

| Befehl | Adre8distanzwert | Verzweigung<br>ausgeführt | Verzweigung<br>∩icht ausgeführt |  |
|--------|------------------|---------------------------|---------------------------------|--|
| Baa    | Byte             | 10(2/0)                   | 8(1/0)                          |  |
| Bcc    | Worl             | 10(2/0)                   | 12(2/0)                         |  |
| BRA    | Byte             | 10(2'0)                   | -                               |  |
|        | Wort             | 10(2/0)                   |                                 |  |
| BSR    | Byte             | 18(2/2)                   |                                 |  |
|        | Wort             | 18(2/2)                   | _                               |  |
| DBCC   | CC wahr          |                           | 12(2/0)                         |  |
|        | CC falsch        | 10(2/0)                   | 14(2/0)                         |  |

<sup>+</sup> Addieren Sie die zur Berechnung der effektiven Adresse benötigte Zeit

n ist die Anzahl der Bitpositionen, um die verschoben wird

<sup>\*</sup> Zeigt Maximalwert an

<sup>\*</sup> Zeigt Maximalwert an

# JMP, JSR, LEA, PEA und MOVEM

| Befehl | Größe           | (An)               | (An)+               | ~( <b>A</b> n)   | d(An)             | d(An, ix)+      | W.xxx                | JOOK.L               | d(PC)                      | d(PC, ix)*        |
|--------|-----------------|--------------------|---------------------|------------------|-------------------|-----------------|----------------------|----------------------|----------------------------|-------------------|
| JMP    | -               | 8(2/0)             | -                   | -                | 10(2/0)           | 14(3/0)         | 10(2/0)              | 12(3/0)              | 10(2/0)                    | 14(3/0)           |
| JSR    | -               | 16(2/2)            | -                   | - :              | 18(2/2)           | 22(2/2)         | 18(2/2)              | 20(3/2)              | 18(2/2)                    | 22(2/2)           |
| LEA    | -               | 4(1/0)             | -                   | -                | 8(2/0)            | 12(2/0)         | 8(2/0)               | 12(3/0)              | B(2/0)                     | 12(2/0)           |
| PEA    | -               | 12(1/2)            | -                   | -                | 16(2/2)           | 20(2/2)         | 16(2.2)              | 20(3/2)              | 16(2/2)                    | 20(2/2)           |
| MOVEM  | Wort            | 12 + 4n<br>(3+n/0) | 12 + 4n<br>(3+n/0)  | -                | 16+4n<br>(4+n/0)  | 1               | 16 + 4n<br>(4 + n/0) | 20 ± 4n<br>(5 ± n/0) | 16+4n<br>(4+n/0)           | 18+4n<br>(4+n/0)  |
| M⊸R    | Doppel-<br>wort | 12+8n<br>(3+2n/0)  | 12 + 8n<br>(3+2n/0) |                  | 16+8n<br>(4+2n/0) |                 | 16+9n<br>(4+2n/0)    | 20+8n<br>(5+2n/0)    | 1 <b>6+8</b> n<br>(4+2n/0) | 18+8n<br>(4+2n/0) |
| MOVEM  | Wort            | 8+4n<br>(2/n)      |                     | 8+4n<br>(2/n)    | 12+4n<br>(3/n)    |                 | 12+4n<br>(3/n)       |                      | -                          | -                 |
| R⊸M    | Doppel-<br>wort | 8 + 8n<br>(2/2n)   |                     | 8 + 8n<br>(2/2n) | 12+8n<br>(3/2n)   | 14+8n<br>(3/2n) | 12+8n<br>(3/2n)      | 16+8<br>(4/2n)       | -                          | -                 |

n ist die Anzahl zu bewegender Registerinhalte.

# Mehrfachgenaue Befehle

| Befehl | Größe      | Op Dn, Dn | Op M M  |
|--------|------------|-----------|---------|
| ADDX   | Byte, Wort | 4(1/0)    | 18(3/1) |
|        | Doppelwort | 8(1/0)    | 305/2)  |
| СМРМ   | Byte, Wort | -         | 12(3/0) |
|        | Doppelwort | -         | 20(5/0) |
| SUBX   | Byte, Wort | 4(1/0)    | 18(3.1) |
| 3007   | Doppelwort | B(1/0)    | 305/2)  |
| ABCD   | Byte       | 6(1/0)    | 18(3/1) |
| SBCD   | Byte       | 6(1/0)    | 18(3/1) |

<sup>\*</sup> Die Größe des Indexreg sters (ix) beeinflußt nicht die Ausführungsze t

# Verschiedene Befehle

| Befehl        | Größe      | Register | Speicher  |
|---------------|------------|----------|-----------|
| ANDI to CCR   | Byte       | 20(3/0)  | -         |
| ANDI to SR    | Wort       | 20(3/0)  | -         |
| CHK           |            | 10(1/0)+ | -         |
| EORI to CCR   | Byte       | 20(3/0)  |           |
| EORI to SR    | Wort       | 20(3/0)  | -         |
| ORI to CCR    | Byte       | 20(3/0)  | -         |
| ORHo SR       | Wort       | 20(3/0)  | -         |
| MOVE from SR  | -          | 6(1/0)   | B(1/1)+   |
| MOVE to CCR   | -          | 12(2/0)  | 12(2/0)+  |
| MOVE to SR    | -          | 12(2/0)  | 12(2/0) + |
| EXG           | -          | 6(1/0)   | _         |
| EXT           | Wort       | 4(1/0)   | -         |
| EVI           | Doppelwort | 4(1/0)   | -         |
| LINK          |            | 16(2/2)  | _         |
| MOVE from USP | -          | 4(1/0)   | -         |
| MOVE to USP   | -          | 4(1/0)   | -         |
| NOP           | -          | 4(1/0)   | -         |
| RESET         | -          | 132(1/0) | -         |
| RTE           |            | 20(5/0)  |           |
| RTR           | -          | 20(5/0)  | -         |
| RTS           | -          | 16(4/0)  | -         |
| STOP          | -          | 4(0/0)   | -         |
| SWAP          | -          | 4(1/0)   | -         |
| TRAPV         | -          | 4(1/0)   | -         |
| UNLK          | -          | 12(3/0)  | -         |

<sup>+</sup> Addieren Sie die zur Berechnung der effektiven Adresse benötigte Zeit

# MOVEP

| Befehl | Größe      | Register - Speicher | Speicher + Register |
|--------|------------|---------------------|---------------------|
| MOVEP  | Wort       | 16(2/2)             | 16(4/0)             |
| IMOVEL | Doppelwort | 24(2/4)             | 24(6/0)             |

#### Ausnahme-Prozeduren

| Ausnahme            | Zyklen   |
|---------------------|----------|
| Adreßfehler         | 50(4/7)  |
| Bustehler           | 50(4/7)  |
| CHK-Belehl          | 44(5/4)+ |
| Division durch Null | 42(5/4)  |
| -liegaler Befehl    | 34(4/3)  |
| Unterbrechung       | 44(5/3)* |
| Privilegverletzung  | 34(4/3)  |
| RESET **            | 40(6/0)  |
| Trace               | 34(4/3)  |
| THAP-Belehl         | 38(4/4)  |
| TRAPV-Befehl        | 34(4/3)  |

- Addieren Sie die zur Berechnung der effektiven Adresse benötigte Zeit
- \* Es wird angenommen, daß der Unterbrechungserkennungszyklus vier Taktzyklen dauert
- " Zeit vor der Erkennung, daß RESET und HALT akt v sind bis zum Beginn der Befehlsausführung

#### Ausnahme-Prozeduren

| Ausnahme               |           |
|------------------------|-----------|
| Adreßfehler            | 126(4/26) |
| Breakpoint-Betehl      | 42(5/4)   |
| Bustehler              | 126(4/26) |
| CHK-Befehf**           | 44(5/4)+  |
| Division durch Null    | 44(5/4)   |
| Illegaler Befehl       | 38(4/4)   |
| Unterbrechung          | 46(5/4)   |
| illegaler Cr**         | 46(5/4)   |
| Privilegverletzung     | 38(4/4)   |
| Reset***               | 40(6/0)   |
| RTE, illegales Format  | 50(7/4)   |
| ATE, illegale Revision | 70(12/4)  |
| Trace                  | 38(4/4)   |
| TRAP-Betehl            | 38(4/4)   |
| TRAPV-Befehl           | 40(5/4)   |

- + Addieren Sie die zur Berechnung der effektiven Adresse benötigte Zeit
- Es wird angenommen, daß die Unterbrechungserkennungs- und Breakpoint-Zyklen vier Taktzyklen dauern
- Zeigt Maximalwert an.
   Gibt die Zeit an, die von der ersten Erkennung von RESET und HALT bis zum Beginn der Ausführung des Befehls vergeht

# Stichwortverzeichnis

## 6800-Bausteine 65 ABCD 166, 316 Absolute Adressierung 114 Absteigender Stapel 135 ADD 168 ADDA 170 ADDI 171 ADDQ 173 ADDX 175 Adreßbus 14 Adreßdistanzwert Adreßfehler 104 Adressierung - absolute 114 - direkte 121 - gerade 107 - indirekte 129 - relative 144 - relative mit Index 150 - ungerade 107 - unmittelbare 126 Adressierungsarten 113, 155 Adreßregister 24, 123 AND 177 **ANDI 179** ANDI mit CCR 181 ANDI mit SR 182 Anwender-Modus 19, 78 Anwender-Unterbrechung 91 AS 14 ASL. ASR 183, 320 Asynchron-Modus 14, 31, 57 Aufsteigender Stapel 134 Ausnahme 83 Ausnahmeprozedur 49 Ausnahmetypen 86 Ausnahmevektoren 80, 81 Ausnahmeverarbeitung 100 Ausnahmezustand 77, 98, 101

Autovektorielle Unterbrechung

Autovektornummer 88

49, 93, 94

Bcc 148, 186, 302 BCHG 188, 345 BCLR 190, 345 Bedingungscoderegister 110 Bedingungscodes Befehlsliste 157 Befehlssatz 155 Befehlszyklus 28 BEQ 149 BERR 17, 48, 54, 103 Bestimmungsoperand 109 BG 16, 17, 69, 71 BGACK 16, 17, 69, 73 BR 16, 68, 71 BRA 192 BSET 193, 344 BSR 195 BTST 196, 343, 344 Busanforderung 68 Busfehler 103, 104 Bussteuerung 68 Buszyklus 28 Byte 23, 107 Byte-Adresse 108

Cache-Speicher 425 Carry 27 CCR 110 CHK 100, 198, 322 CLK 11, 12 CLR 200 CMP 202 CMPA 204 CMPI 206 CMPM 208

Datenbus 14
Datenlängencode 108
Datenregister 24
DBcc 210, 305
DC 160, 161
DFC 402
Direkte Registeradressierung 121

DIVS 100, 212, 312 DIVU 100, 214, 312 DMAC 6844 73, 74 Doppelfehler 103 Doppelwort 23, 107 Doppelwort-Adresse 108 DS 161 DTACK 14, 16

E 19
EA 121
Effektive Adresse 121
Einzelschritt-Modus 55, 56
END 163
ENDC 163
ENDM 163
EOR 216
EORI 218
EORI mit CCR 220
EORI mit SR 221
EQU 162
EXG 222
EXT 223, 311
Extend 27

FCO 19 FC1 19 FC2 19 FIFO 134 Funktionscode-Register 402 Funktionscodes 19

# Gerade Adressierung 107

HALT 17, 18, 54, 55 Haltezustand 77

TACK 23
IFEQ 163
IFNE 163
ILLEGAL 224
Illegaler Befehl 100
Index 140
Indirekte Adressierung 129
Interner Aufbau 23
Interrupt 26
IPL0 17, 86, 94
IPL1 17, 86, 94
IPL2 17, 86, 94
IROB 94
IROB 94

JMP 225 JSR 226

Label 146 Langwort 107 LEA 227, 304 Lese-/Änderungs-/ Schreibzyklus 45-48 Lesezyklus 31, 33 LINK 228, 346 LIFO 133 LLEN 164 LSL, LSR 229, 320

MACRO 163 Master 31 MOVE 232 MOVEA 240 MOVEM 241 MOVEP 245 MOVEQ 248 MOVE USP 239 MOVE von SR 238 MOVE zum CCR 234 MOVE zum SR 236 MULS 249 MULU 251

NBCD 253, 316, 319 NEG 255 Negative 27 NEGX 257 Nicht-autovektorielle Unterbrechung 88–90 Nichtimplementierter Befehl 100 NOOBJ 164 NOP 259 Normalzustand 77 NOT 260 Notation 165 Null-Bit 27

OR 262 ORG 147, 159 ORI 264 ORI mit CCR 266 ORI mit SR 267 Overflow 27

PC 24 PEA 268 PLEN 164 Postinkrement 130 Predekrement 131 Prioritätsebenen 86 Privilegierte Befehle 101 Privilegverletzung 101 Programmzähler 24 Puffer 65

Quelle 108, 109 Queue 134, 136

R/W 14
Relative Adressierung 144
Relative Adressierung mit Index 150
Re-run 50
RESET 17, 18, 95, 97, 98
RESET 269
RESET-Vektor 80
ROL, ROR 270, 320
RORG 147, 160
ROXL, ROXR 273, 320
RTE 276
RTR 277
RTS 278

SBCD 279, 316, 319 Sec 281, 315 Schreibzyklus 40-45 Semaphore-Register 340 Senke 109 SET 162 SFC 402 Slave 31 SPC 165 Speicher 107 SR 24 Stack 133 Stapel 133 - absteigender 135 - aufsteigender 134 Stapelzeiger 27 Statusregister 24, 125 STOP 283 SUB 284 **SUBA 286** SUBI 288 **SUBQ 290** SUBX 292

Supervisorebene 26

Supervisor-Modus 19 Swait 35 SWAP 294, 311 Synchrone Datenübertragung 58-64 System-Bit 26 Systemebene 26

Takteingang 12 Taktgeber 11 Taktzyklus 28 TAS 45, 295, 337 TRACE 101 TRAP 98, 297 TRAPV 100, 298 TST 299 TTL 165

UDS, LDS 14
Überlauf 27
Übertrag 27
Überwachungsmodus 78, 79
UNLK 301, 349
Unmittelbare Adressierung 126
Unterbrechung

- Anwender-Unterbrechung 91
- autovektorielle 49, 93, 94
- nicht-autovektorielle 88-90
Unterbrechungsmaske 26, 86
Unterbrechungspunkt 409

VBR 402 Vektorbasisregister 402 Vektornummer 80, 83 Verzweigungsbefehle 148 Virtuelle Maschine 401 Virtueller Speicher 401 VMĀ 19 Vorzeichen-Bit 27 VPĀ 19, 88

Warteschlange 134, 136 Wartezustände 35 Wort 23, 107 Wort-Adresse 108

Zero 27 Zieloperand 109 Zyklusstörungen 48